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SECTION I 
GENERAL INFORMATION 


1,1 SCOPE OF MANUAL 


This is the second of two manuals describing the Model 980 Computer assem- 
bly language, and it is written for the user interested in controlling all input/ 
output (I/O) operations. Section II of this manual describes the two methods 
of performing I/O with the computer, and contains examples of both meth- 
ods. Included in Section II is a discussion of interrupts and related pro- 
gramming techniques, Section III discusses some of the considerations ap- 
plicable to systems programming. Section IV provides a detailed look at 

I/O programming considerations related to the 733 ASR/KSR data terminals 
and the Full Duplex EIA Communications Module used to interface the ter- 
minals to the computer. The single appendix at the end of the manual con- 
tains a list of USASCII characters, 


12 REFERENCES 


The other manual covering the Model 980 assembly language is Model 980 
Computer Assembly Language Programmer's Reference Manual, This man- 
ual describes both the machine instructions and coding conventions associated 
with the Model 980 assembly language, 


If the user does not want to control all I/O, the Basic System provides two 
alternate methods of performing I/O. First, if a 980 FORTRAN compiler is 
part of the Basic System, the Format Editor portion of the compiler can be 
linked to the user's program to provide easy, formatted I/O. This method 


is described in Model 980 Computer FORTRAN Library and IAL. The sec- 
ond method is to use the I/O package as described in Model 980 Computer 


Basic System Use and Operation, This manual contains the information nec- 
essary to load and execute a machine language program; or to assemble, 
load, and execute a stand alone assembly language program, The related 
software manuals and their respective manual numbers are listed in table 
1-1, 


Table l1-l. Related Manuals 


Model 980 Computer Assembly Language Program- 
mer's Reference Manual 


943013-9701 


Model 980 Computer Basic System Use and Opera- 
tion 


Model 980 Computer FORTRAN Library and IAL 


961961-9710 
961961-9744 
943000-9701 


Model 980 Computer Programming Card 
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‘SEG TION IL 
INPUT/OUTPUT PROGRAMMING 


2.1 METHODS 


The Model 980 Computer has two types of I/O ports: the data bus and the di- 
rect memory access channel (DMAC). The characteristics of the devices 
attached to these ports, and the methods of performing I/O, vary consider- 
ably. 


Data bus devices have a relatively slow rate of transfer, Data is moved to 
or from the device via the computer one word, or one character, ata time. 
Since only a small amount of data is moved in a given time interval, the soft- 
ware overhead required to handle each word or character is acceptable, The 
data bus should be used for devices with a slow transfer rate, because the 
interfaces are less expensive than those required for the DMAC. The 733 
ASR/KSR, paper tape reader, and teleprinter are examples of data bus de- 
vices. 


DMAC devices are relatively fast, Entire buffers of data may be moved to 
or from these devices without program intervention. The speed of the de- 
vices precludes software handling of each word or character as it is moved. 
Examples of devices that should interface with the DMAC are magnetic tape 
and disc drives. 


Both data bus and DMAC I/O may be performed with or without the use of 
interrupts. If interrupts are used, the interface issues a signal to the com- 
puter each time some action is required by the software, The signal causes 
the computer to ''trap''; that is, rather than executing the next sequential in- 
struction, an instruction at a specific trap location is executed. This in- 
struction is normally a store status and branch instruction (SSB) which trans- 
fers control to a program that performs the service requested by the device. 


If interrupts are not used, the program performing the I/O operation must 
periodically test the status of the appropriate device. A change in status is 
comparable to an interrupt in that both require some action to be taken by 
the program. 


2.2 DATA BUS INPUT/OUTPUT 


The data bus provides a path for single word (16-bit) parallel transfers be- 
tween the computer and external devices. Four data bus ports are standard 
in the computer; however, the number of ports may be expanded to a maxi- 
mum of 256. The external devices connected through these ports are ad- 
dressable in four groups of 64 addresses, and the assignment of a device to 
an address is completely arbitrary. The computer instruction repertoire in- 
cludes the Write Direct Single (WDS) and Read Direct Single (RDS) instruc- 
tions to control data bus operations. The WDS instruction is used to perform 
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a 16-bit write to the addressed external device and the RDS instruction per- 
forms a 16-bit read from the addressed external device. 


Both WDS and RDS are two-word instructions, formatted as shown in figure 
2-1. Table 2-1 provides a descriptive breakdown of the bit-fields in both 
words. A data word containing a character and/or control information is 
associated with each WDS and RDS instruction, The content of the data word 
depends on the type of instruction (WDS or RDS) and the external device in- 
volved in the communications. When a WDS or RDS instruction is executed, 
the first word of the instruction is applied to the I/O data bus. The device 
controller addressed by the external register field must then determine if it 
is ready to transmit or receive, as specified by bit 10 of the first word of the 
instruction. If the device controller returns an acknowledge signal to the 
computer signifying the transfer took place, the program continues, If the 
busy bit in the second word of the instruction is set and the device controller 
does not return an acknowledge signal, the external device is not ready for 
the latest WDS or RDS instruction. In this case, the next sequential instruc- 
tion (commonly a branch to re-try the WDS or RDS instruction) is executed, 


Although all I/O device controllers have the capability of being strapped for 
any external register number, standard assignments have been made for 
group zero to facilitate documentation, All standard 980 software furnished 
by Texas Instruments will address the devices with the assigned numbers 
shown in figure 2-2 and table 2-2, 


(a) 4 5 


7 8 9 10 #11 15 
ER= 
R/W] EXTERNAL REGISTER 


Oo —- RDS 
1 —- WDS 


11 


12 13 15 
R= 

A INTERNAL § 
REGISTER | 


WORD 2 


10 
B ~- BUSY BIT 


1 - INCREMENT ADDRESS 
A -— ADDRESS MODE 


{(A)129602 


Figure 2-1. WDS/RDS Instruction Format 
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Table 2-1. WDS/RDS Instruction Field Breakdown 


_ Word/Bit(s) Description 


1/0-4, 7, 8 Op-code bits. 


1/5, 6 . Group bits, used to define 1 of 4 groups. Each group can 
be used to specify up to 64 external devices. The group 
and external register fields combine to specify the exter- 
nal device involved in the WDS/RDS instruction. Typi- 
cally, the group bits are zero unless the expansion of data 
bus ports exceeds 64, 


1/9, 11-15 External register bits, used to specify 1 of 64 devices in 
the selected group. 


1/10 Read/write bit, used to specify either a RDS or WDS in- 
struction, A logic zero specifies a RDS instruction; a 
logic one specifies a WDS instruction, 


2/0-7, 9,11 Not used, 


2/8 Busy bit, an optional field (B) used with external devices 
that may not be ready to transfer data when queried by the 
computer, If this bit is a logic one and a successful data 
transfer takes place, the instruction following the WDS/ 
RDS instruction is skipped. If this bit is a logic one and 
no data transfer takes place, the instruction following 

the WDS/RDS instruction is executed. If this bit is a 
logic zero, the device transfers data unconditionally and 
the instruction following the WDS/RDS instruction is ex- 
ecuted. 


Increment (I) field, used in conjunction with the A field 

(bit 12 of word 2) to increment or decrement the contents 
of the register specified by the R field (bits 13 to 15 of 

word 2). If both the Iand A fields are logic ones, the ad- 
dress contained in the register specified by the R field is 
incremented by one each time a data word is transferred. 
If the A field is a logic one, but the I field is a logic zero, 
the address contained in the register specified by the R is 
decremented by one each time a data word is transferred. 


Address (A) mode field, used to specify indirect address- 
ing. If the A field is a logic zero, data is transferred to 
or from the register specified by the R field. If the A field 
is a logic one, data is transferred to or from the memory 
location specified by the contents of register R. 


2/13-15 Register (R) field, used to specify 1 of 8 internal regis- 
ters in the computer, The specified register holds the 
data or the address of data involved in the transfer. 
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BITS 12,13,14,15 (HEX) 


bdtins COMMUNI-— COMMUNI— COMMUNI- 
COMMUN I-— CATION CATION 
MODULE MODULE 


3 4 


COMMUNI-— COMMUN I- COMMUNI-— 
CATION CATION CATION 
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Table 2-2. Standard 980. External Register/Function Details 


Register 
Number 
(Hex) 
Bits (9-15) 


Device 


PIF - Privileged Instruc- 
tion Feature 


PIF - Privileged Instruc- 
tion Feature 


Customer Use 
Customer Use 
Interval Timer 


Communication Module 
(Primary Addr.) 
33 ASR, 733 ASR/KSR 
or CRT © 
New Interface P/N 
966637 


Communication Module 


(Secondary Addr.) 


Customer Use 
Customer Use 
Customer Use 
Customer Use 
Customer Use 


Communication Module 
(Secondary Addr.) 


Communication Module 
(Secondary Addr.) 


PTR - Paper Tape Reader 


PTP - Paper Tape Punch 


een enn 


Function 


Out - Set lower memory 
boundary 


Out - Set upper memory 
boundary 


In - Input data and Status 


Out - Output data and Com- 
mands 


In - Input data and Status 
Out - Output data and Com- 
mands 


In - Input data and Status 
Out - Output data and Com- 
mands 


In - Input data and Status 
Out - Output data and Com- 
mands 


In - Read status 
Out - Write command 


In - Read status 
Out - Write command 
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Table 2-2. Standard 980 External Register/Function 
Details (Continued) 


Register 


Be lace Device Function 
(Hex) 
Bits (9-15) 
INT - Interrupt Expander In - Read interrupt 


Address for 
Expander Chassis 
Interrupt Expander is 
relative to board loca- 
tion 
Customer Use 
Customer Use 
Customer Use 
PTR - Paper Tape Reader In - Read data 
PTP - Paper Tape Punch Out - Write data 
Customer Use 


Customer Use 


CDR - Card Reader In - Read status and data 
Out - Write command 


Customer Use 
Customer Use 


ADA - Analog to Digital Data Module - (See ADA 
Converter or Digital to User's Manual) 
Analog Converter 


LLP - Low Speed Line Data Module - (See Line 
Printer Printer User's Manual) 


Vectored Interrupt (I/O slot | Set Mask 
1&2) 


Vectored Interrupt (I/O slot | Clear Mask 
1&2) 


Vectored Interrupt (1/O slot Set Interrupt (T) 
1&2) 


eretalerenen oe 


(T) Test Only 
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Table 2-2. Standard 980 External Register/Function 
Details (Continued) 


Register 
- Number 
(Hex) 
Bits (9-15) 


Device . . Function 


Vectored Interrupt (I/O slot | Set Mask 
3&4) 


Vectored Interrupt (I/O slot | Clear Mask 
3&4) | 


Vectored Interrupt (I/O slot | Set Interrupt (T) 
3&4) | 


(T) Test Only 


Programming examples are included in this section for some of the I/O data 
bus peripheral devices. The 16-bit operands for the RDS and WDS instruc- 
tions are calculated as follows: . 


@ The assembler puts the correct information in bits 0-4, 7, 8, and 
10, Bit 10 designates whether the instruction is an RDS(0) ora 
WDS(1). 

e The external register/function number to be used is designated in 


bits 9 and 11-15 and is shown in figure 2-2 and listed in table 2-2. 
The group is zero in all of the examples in the following pages, and 
is defined in bits 5 and 6, 


For example, in order to read a character from the high speed paper tape 
reader (PTR): 


1, Locate PTR input in figure 2-2, The register/function numbers 
are found to be 101;¢ and 18]¢. 


2. Table 2-2 shows that PTR input on register 1014 reads status, and 
that PTR input on register 18);¢ reads data. 


3, In this example, register 1816 is the required register/function 
number. Thus 0018)¢ is the required operand for group zero, 


4, If some group other than zero is to be used, the group number must 
be placed in bits 5 and 6. Thus, for group three, the operand 
would be 0618 1¢. 


The second word of the RDS and WDS examples that follow may specify the 
device busy test in bit 8. Computer register A (zero) is used as the internal 
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register in bits 13-15 to receive or transmit data, Bits 10 and 12 are zero 
to indicate that register A does not contain a memory address nor is it to be 
incremented, Bits 0 through 7, 9, and 1l are not used. Thus, the second 
word of an RDS to read a character from the high speed paper tape reader 
into register A is 0080;¢. The quantity 2080,¢ may be used for compatibility 
with previous models of the computer. Most of the examples do include 
200016 in the second word of the instruction so that they may be assembled 
and executed on the 980A or 980B as well as previous models of the com- 
puter, 


The following paragraphs contain specific examples of common I/O opera- 
tions; however, these examples do not represent the only way the operations 
may be performed, For further information, the user should consult the 
appropriate I/O data bus User's Manual for the Model 980 Computer. Each 
programming example is followed by a table that explains the appropriate 
command/status bits for the peripheral device being discussed. 


NOTE 


The I/O examples included in this section of the 
manual assume that the mnemonics used in the 
operand fields have been adequately defined, 
The mnemonics could be defined as follows: 


HED DATA BUS I/0 TEST 


A EOU 0 
X EQU 2 

IN BSS 100 

OUT DATA 'ABCDEFGHI¥9! 


MINSEC BSS 1 
HOURS BSS 1 
DAYS BSS 1 


; INPUT/OUTPUT CODING 


IDL 
END 


2.2.1 HIGH SPEED PAPER TAPE READER 


The high speed paper tape reader has two external registers: data and 
command/status. Usually these registers are 18,4 and 10)¢, respectively. 
The command/status register bit definitions are listed in table 2-3, 
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Table 2-3, High Speed Tape Reader 
Command/Status Bits | 


Bit 
a a ee a ee ae a 


Disconnect 


No disconnect 


Interrupt No interrupt 


Interrupts No action 


enabled 


Interrupts 
enabled 


Interrupts 
disabled 


No action Ps = 


Stop reader 


Read 
forward 


No action es = 


The program listed below turns on the reader, reads 10 characters, and 
turns off the reader. 


LDA = BIT 15 TURNS ON HSR 
WDS >10 OUT TO COMMAND REG. 
DATA >2080 WITH BUSY BIT TEST 
BRU $-2 REPEAT UNTIL HSR ON 
LDX =-10 SET UP FOR 10 CHAR 
RDS =>18 READ CHAR RIGHT ADJ 
DATA >2080 WITH, BUSY BIT TEST 
BRU $-2 REPEAT IF NOT READY 
STA IN+10,X SAVE CHARACTER 

BIX $-4 LOOP BACK 

LDA = BIT 13 TURNS OFF 
WDS >10 OUT TO COMMAND REG 


DATA 2000 NO BUSY BIT TEST 


Zv2cc: HIGH SPEED PAPER TAPE: PUNGH 


The high speed paper tape punch has two external registers: data and 
command/status. Normally these registers are 18,4 and 11164, respectively. 
The command/status register bit definitions are listed in table 2-4. 


see Seca SSS SSS SS > SS: 
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Table 2-4, High Speed Paper Tape Punch 
Command/Status Bits 


Commands Status 


a a ae 


Disconnect |No disconnect | Interrupt No interrupt 
punch 


Enable No action Interrupts Disabled 
interrupts ‘enabled 


The following program punches a leader, punches 10 characters and punches 
a trailer. 


LDX =-120 SET UP FOR 12 INCH 
LDA =0 BLANK FRAMES LEADER 
WDS >18 OUT TO HSP 

DATA >2080 WITH BUSY BIT TEST 
BRU $-2 REPEAT IF NOT READY 
BIX $-3 LOOP BACK 

LDX =-10 SET UP FOR 10 CHAR 
LDA OUT+10,X GET CHAR RIGHT ADJ 
WDS >18 OUT TO HSP 

DATA  >2080 WITH BUSY BIT TEST 
BRU $~2 REPEAT IF NOT READY 
BIX $-4 LOOP BACK 

LDX =-120 SET UP FOR 12 INCH 
LDA =0 BLANK FRAMES TRAIL 
WDS >18 OUT TO HSP 

DATA >2080 WITH BUSY BIT TEST 
BRU Gu REPEAT IF NOT READY 
BIX $-3 LOOP BACK 


2.2.3 CARD READER 


The card reader has one external register, normally 1F1¢, used for both 

status/data and command, The command/status register bit definitions are 
listed in table 2-5, During a read operation, the least significant 12 bits of 
the register contain the contents of the last column read, and the most sig- 
nificant four bits contain the status. The data is placed in the register with 


 emamad 
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Table 2-5. Card Reader Command/Status Bits 


Sa OD 


0 - No error 


Zz - No end of 
card 


14 Skip to end | No skip 
of card 


15 Feed card No feed 
card 


Note: Errors that inhibit data transfer (i.e., feed and read 
errors) are indicated by a light on the card reader; 
operator intervention is required. 


the row 9 in bit 4, row 8 in bit 5, etc. The following is a program to feeda 
card and read its contents. Note that device status is tested. 


LDA = BIT 15 FEEDS A CARD 

WDS >1F OUT TO CARD READER 

DATA 2080 WITH BUSY BIT TEST 

BRU $-2 REPEAT IF NOT READY 

LDX =-60 SET UP FOR 60 COL 
READ RDS >1F READ A COLUMN 

DATA >2080 WITH BUSY BIT TEST 

BRU $-2 REPEAT IF NOT READY 

LRD 12 SEPARATE DATA/STAT 

SZE -A TEST FOR ERROR 

BRU ERROR PROCESS ERROR 

LLD 12 RIGHT ADJ DATA 

STA. IN+60,X SAVE DATA 

BIX READ LOOP BACK 


a ge nS PSS SSS == SSS SSS SSeS Sess ee caPCAAY 
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2.2.4 DATA MODULE 


Many peripherals may be connected to the 980 through the I/O data module 
interface. The command and status information listed in table 2-6 is for the 
data module in general. Specific information for a peripheral may be ob- 
tained from the appropriate User's Manual furnished by Texas Instruments, 
The three peripheral devices that may be connected through the data module 
and have been assigned standard external register numbers are listed in 


ta ble 2- 7. 


*Note: 


*Disconnect 


Enable out- |Disable Output Disabled 
put acknowl- interrupt 
edged enabled 


interrupt 


Enable Input Disabled 
input ready interrupt 
interrupt enabled 


Table 2-6. I/O Data Module Command/Status Bits 


a aoe 


Commands 


*No disconnect 


Output 
interrupt 
pending 


Not pend- 
ing 


Input Not pend- 
interrupt ing 
pending 


The I/O data module Disconnect and No Disconnect 
commands are defined as follows: 


Disconnect - Reset all other command/status bits to 
zero. I/O may continue but command bits 1 and 2 are 
not interrogated. 


No Disconnect - Command bits 1 and 2 are interrogated 
and the appropriate action is taken. 
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Table 2-6. I/O Data Module Command/Status Bits (Continued) 


Output 
Table 2-7. Typical Data Module Peripheral Devices 


Not ready 


word 
ready for 
external 

device 


Output 
word 
acknowl- 
edged 


Input data 
ready 


Not ready 


Not re- 
ceived 


Input data 
received 


External 
Register Function 
(Hex) 


Line Printer - 132 Column 50 (See the Line Printer 
51 User's Manual for the 
ore Model 980 Computer.) 


(See the A/D/A User's 
Manual for the Model 980 
Computer. Two data 


Module 
1 


or Digital to Analog Con- 45 
verter 46 
4C modules are used.) 


Analog to Digital Converter ‘3 


Module 


4D 3 


4E 


The I/O data module interface is designed to transfer data immediately upon 
command, with two exceptions: 


® A busy bit test is required to output a word. 


e After a bit is output, another bit WDS may not be issued for four 
microseconds, (The line marked WAIT in the following example 
performs no function except to provide a 4, 75 microsecond delay.) 


a PS SE SSS SS SS SS se SM A PE NS EP TT STE TE 
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Since the busy bit test does not guarantee valid input data, one of several 
other methods can be used to test data validity as follows: 


Interrupts may be enabled and an interrupt entry point may be de- 
fined for the RDS so that the RDS is performed only after an input 
ready from external device interrupt is received. (See three lines 
of the example beginning at ENABLE plus two lines at INT.) 


If interrupts are not used, status can be read to be sure the input 
is ready before a data RDS is issued, (See six lines of example 
beginning at NOINT.) Note that a status RDS or an output register 
RDS may be issued at any time. 


A bit of the data word can be assigned (through hardware wiring) to 
designate input data validity and can be tested after issuing the RDS 
instruction. 


The following example of programming the I/O data module interface is 
general and does not refer to any of the I/O data module devices that have 
been assigned standard external register/function numbers. The three reg- 
isters used in the example are 48 )¢ through 4A;¢. These registers are cur- 
rently unassigned in figure 2-2. Register 4816 is used for command/ status, 
4914 for data, and 4Aj¢ for read output/bit control, 


ENABLE @LDA =>6000 ENABLE INTERRUPTS 


WDS >48 COMMAND 

DATA >0 REG.A, NO BUSY BIT 

LDA = LOAD REG.A WITH WORD 

WDS >49 OUTPUT WORD 

DATA ->80 WITH BUSY BIT TEST 

BRU $-2 REPEAT IF NOT READY 

LDA. = =>12 TURN BIT 2 ON 

WDS >4A IN OUTPUT REGISTER 

DATA 0 IF ISSUING ANOTHER BIT WDS, 
WAIT CRA = 16 WAIT 4 MICROSECONDS 
NOINT RDS 748 READ STATUS INTO 

DATA 70 REGISTER A 

TABO: 4 CHECK INPUT INTERRUPT 

BRU $-3 REPEAT IF NOT READY 
INT RDS 749g READ THE INPUT 

DATA 70 WHEN IT IS READY 

RDS >4n READ OUTPUT REGISTER 

DATA 0 NO BUSY BIT TEST 


TABO 2 SEE IF BIT 2 HAS BEEN 
, TURNED ON IN THE 
OUTPUT REGISTER 


See TEE cheeemnne en em ees the A SN TEE AR tt rp Se UE a oS Pe Sf SS Prt SPS SSE 
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The format for the WDS data word used by the write bit command involving 
register 4A)¢ of the sample program is shown in figure 2-3. 


c¢) 10 11 12 15 


NOT USED | BIT 


B — VALUE TO BE WRITTEN, ZERO OR ONE 


BIT — SPECIFIC BIT TO BE WRITTEN IN, O-Fig 


(A)129603 


Figure 2-3, WDS Data Word for Write Bit Command 


ZeteD, AINE PRINTER 


The low-speed line printer has three external registers, numbered 501¢, 
5116, and 5216. These registers are used for control/status, write/read 
data, and strobe, respectively. The command/status bit definitions are 
listed in table 2-8. 


Table 2-8. Low Speed Line Printer Command/Status Bits 


Bit 1 0 
Control 0 Reset all Control No action taken 
Commands . 
Logic and Flags 
] Enable Interrupts Disabled Interrupts 
Set Bit asda On6 1716 
Vernmanes Pi to- 15 Set Strobe On Set Strobe Off 
Sree Interrupts Enabled Interrupts Disabled 


Interrupt No Interrupt 
Printer Requesting Data Not Requesting Data 


ASCII character bit patterns are inverted before being written to the printer. 
The inverted character sent is placed in bits 9 through 15 of the specified 
register; bits 0 through 8 must be logic one's, 


The strobe is set on and off by an ''Output Bit'' command, The bit to be set 
is specified in bits 12 through 15, and the value to be set is put in bit 11 of 
the specified register, (Note the two uses of the 'WDS >52"' command in 
the example below.) No other WDS instruction may be sent for four micro- 
seconds following this Output Bit command. 


a 
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Bytes are loaded into a print buffer before being printed by the printer, The 
printer will print the contents of the buffer upon receipt of a carriage return. 


NOTE 


Receipt of the USASCII delete code (7F 6) will 
cause contents of the print buffer to be cleared; 
however, any remaining characters in the rec- 
ord will be entered in the buffer and printed up- 
on receipt of a carriage return, provided another 
delete code is not received. 


The following example will send 10 characters to the printer: 


LDX = -10 SET UP FOR 10 CHAR 
LDA = 0 SET PRINTER STATUS 
WDS > 50 GIVE CONTROL COMMAND 
DATA > 2000 WITHOUT BUSY TEST 
LOOP LDA OUT+10,X GET A CHAR 
AND = >/7F MASK OFF UNWANTED BITS 0 TO 8 
RIV A,A INVERT CHAR, PUT ONES IN TOP 9 BITS 
WDS > 5] OUTPUT CHAR TO PRINTER 
DATA > 2080 WITH BUSY TEST 
BRU $-2 REPEAT IF NOT READY 
RDS > 50 READ STATUS 
DATA > 2000 WITHOUT BUSY TEST 
TABO 6 TEST FOR DEMAND 
BRU $-3 REPEAT TILL DEMAND COMES 
LDA = LOAD SET STROBE COMMAND 
WDS 2 52 OUTPUT STROBE 
DATA > 2000 WITHOUT BUSY TEST 
LLA 13 WAIT 4 MICROSECONDS 
LDA =>17 LOAD SET STROBE OFF COMMAND 
WDS 7 Be OUTPUT STROBE OFF 
DATA > 2000 WITHOUT BUSY TEST 
BIX LOOP REPEAT 


2.2.6 MODEL 912 VIDEO DISPLAY TERMINAL 


The Model 912 Video Display Terminal interfaces with the computer via the 
communications module at one of the external register addresses selected 
from figure 2-2, The single external register assigned to the 912 video ter- 
minal handles commands, status, and data in the format described in para- 
graphs 4.2.1 and 4.2.3. The data field of the WDS format (paragraph 4.2, 1) 
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is used to write USASCII characters to the 912 display and to issue display 

related commands. The data field of the RDS format (paragraph 4.2, 3) is 

used to read USASCII characters from the 912 keyboard. Figure 2-4 shows 
the USASCII character codes used by the 912 display (2016 to 5F16) and the 
display related commands acceptable to the 912 controller. 


MOST SIGNIFLCANT HEX DIGIT 


Pp 
Q 
2 R 
3 S 
4 T 
5 U 
SIGNIFICANT 6 bs 
piGit # w 
8 x 
9 Y 
A z 
B | 
Cc AY 
D | 
E A 
FE = 
HOME~MOVE CURSOR TO FIRST POSITION OF FIRST LINE 
CLEAR-CLEAR DISPLAY AND HOME CURSOR 
CLR EOL-CLEAR CURRENT LINE AND RETURN CURSOR TO 
FIRST POSITION OF CURRENT LINE 
t, }-SINGLE LINE CURSOR CONTROLS 
~)-—-SINGLE CHARACTER POSITION CURSOR CONTROLS 
_BEL~ACTUATE AUDIBLE ALARM (1/2 SECOND) 
(A)129604 


Figure 2-4, 912 Characters and Controls 


The following simplified programming example writes a four-character mes- 
sage to the 912 display, assuming external register 616 is used to interface 
the computer with the associated communications module, 
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LDX =< 
WRITE LDA OUT+4,X LOAD CHARACTER 
AND =>7F MASK OUT BITS 0-8 
@IOR =>5000 WRITE DATA READY, CLEAR WRITE REQUEST 
WDS 6 WRITE TO 912 
DATA >80 ‘ 
BRU $-2 
BIX WRITE WRITE NEXT CHARACTER 
BRU CONT CONTINUE 


OUT DATA ‘HELP! 


22.3 DIRECT MEMORY ACCESS CHANNEL 


The direct memory access channel (DMAC) is the high speed I/O portion of 
the computer, One direct memory access port, capable of I/O with one 
peripheral controller, is included in the basic computer. A direct memory 
access port expander, however, may be added to the DMAC to allow for up 
to eight high-speed peripheral controllers, With a single peripheral device, 
the DMAC can attain a maximum burst rate of 106 words per second; when 
memory access must be granted to more than one peripheral device, the 
effective maximum transfer rate is 8 x 10° words per second, When the 
DMAC expander interfaces with multiple high speed devices, a priority 
scheme selected by the user resolves two or more simultaneous access re- 
quests, All access requests from DMAC related peripheral devices have 
priority over the computer when both require memory access at the same 
time. 


All DMAC I/O is controlled by the Automatic Transfer Instruction (ATI). 
ATI is a two-word instruction, formatted as shown in figure 2-5, When data 
must be transferred between computer memory and a device controller on 
the DMAC, the ATI instruction is used. The first word of the instruction 


(e) 7 8 12 13 15 
OP= DEVICE/ 
WORD 1 OPERATION CODE DEVICE DEPENDENT CHANNEL 
ADDRESS 
fe) 15 
WORD 2 | CONTROL. WORD OR MEMORY ADDRESS | 


(A)129605 


Figure 2-5, ATI Instruction Format 


EEN PORES ep REN PO A SES A, MARY PRE AACE A ST ERTS TST 
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format addresses one of. eight possible device controllers (bits 13 to 15) and 
supplies any necessary device dependent data (bits 8 to 12), The second 
word of the format is routed to the addressed device controller where it is 
interpreted as a single word functional command or as an address pointing 
to a list in memory containing command related data. Command lists typi- 
cally contain one or more blocks of data, each constructed from the follow- 
ing elements: 


® Command Function - Operation to be performed, such as read or 
write. 

@ Buffer Address - Memory address for data transfer. 

@ Buffer Length - Character or word length of record to be trans- 
ferred, 

e External Address - Address within external media of data for 
transfer, | | 

s Interrupt Enable - Instructs device controller whether or not to 


generate an interrupt upon completion of data transfer, 
e Chaining Information - Linkage to next command list, if any. 


In addition to the ATI instruction and any related command lists, the DMAC 
device controllers interface with the computer by reporting status to dedi- 
cated memory locations, The dedicated memory location associated with a 
device depends on the DMAC port number used to address the device. Table 
2-9 lists the port numbers and related memory locations, 


Table 2-9, DMAC Device Status Memory Locations 


DMAC Port Memory Location 
(Hex) 
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The following is a typical example of code to perform an operation with a 
DMAC device. The device status location is set to some illegal value (usually 
all zeros), the ATI is issued, and then a test is performed repeatedly looking 
for a change in status, This change indicates the operation is complete, The 
status should then be tested to determine whether or not an error was detected 
during performance of the operation, The ATI specifies the device port and 
the command to be executed. 


LDA = =0 INITIAL VALUE 
STA *STATUS —- STORE IN STATUS LOC 
ATI ‘DEVICE ISSUE ATI 


DATA LIST ATI LIST POINTER 
LDA *STATUS OBTAIN STATUS 

SNZ A TEST FOR CHANGE 

BRU $-2 REPEAT IF NO CHANGE 
CPL LEGAL TEST FOR OK STATUS 
SEQ CONTINUE IF OK 

BRU ERROR IF NOT PROCESS ERR 


The next four paragraphs cover programming details for four types of 
DMAC devices. For further information, consult the Model 960/980 Com- 


puter DMAC Controller manual. 


2.3.1 LINE PRINTER 


The high speed line printer normally occupies DMAC expander port 5 (ifa 
DMAC expander is used), and it stores status in memory location 00AZ2_,. 
The line printer command list words format is shown in figure 2-6 and the 
returned status words are detailed in table 2-10. 


O LIST 15 
WORD 1 DATA ADDRESS 
WORD 2 CHARACTER COUNT 
Ww BIT O 1-ISSUE INTERRUPT O-DO NOT INTERRUPT 
ORD 3 BIT 2 1—-CHAIN O-DO NOT CHAIN 
WORD 4 ADDRESS OF NEXT LIST, IF CHAINING 
(A)129606 


Figure 2-6, Line Printer Command List Words Format 
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Table 2-10. Line Printer Status Word Bits 


Controller busy 
Status 


Word 1 Printer not ready 


Operation complete Not complete 


Note: Status word 2 not used, 


The following programming example prints 100 characters on the line printer 
from reserved memory named BUFFER. The write is to be done without 
interrupts or chaining, 


LDA =0 

STA *STATUS CLEAR STATUS 

ATI 5 ISSUE ATI 

DATA LIST ATI LIST POINTER 

LDA *STATUS OBTAIN STATUS 

SNZ A TEST FOR CHANGE 

BRU $-2 REPEAT IF NO CHANGE | 
CPL = TEST FOR OPERATION COMPLETE 
SEQ CONTINUE IF COMPLETE 

BRU ERROR BRANCH TO ERROR ROUTINE 
BRU CONT CONTINUE 


STATUS DATA >A2 
LIST DATA  BUFFER,100,0,0 
BUFFER BSS 50 


2.3.2 FIXED-HEAD DISC 


The fixed-head disc controller normally occupies DMAC expander port 0 (if 
a DMAC expander is used) and stores status in memory locations 0098), and 
009916. The fixed-head disc command list words format is shown in figure 
2-7 and the returned status words are detailed in table 2-11. 


The first ATI word for the fixed-head disc controller specifies unit number 
as well as port number. The unit number is specified in bits 10 andll. A 
maximum of four discs may be attached to the computer, but a command 

cannot be issued to one unit while another unit is in operation. The sample 
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WORD 1 
WORD 2 
WORD 3 
WORD 4 ADDRESS OF NEXT LIST, IF CHAINING 
* CONTROL BIT BREAKDOWN 
Bit 4 0 
0 Issue interrupt Do not interrupt 
1 Write Read 
pe Chain Do not chain 
(A)129607 3 Compare disc with memory No compare 
Figure 2-7. Fixed-Head Disc Command List Words Format 
Table 2-11, Fixed-Head Disc Status Word Bits 
Next chain list taken Not yet taken 
Timing error No error 
Program error No error 
Status 
Compare error No error 


Word 1 


Note: 


Parity error 


Controller busy 


Unit not ready 
Write lockout enabled 


Operation complete 


Status word 2 - address of last list executed, 


No error 

Not busy 

Ready 

No write lockout 


Not yet complete 


Digital Systems Division 
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ATI is for disc number 3 on port 0. The list specifies that three sectors are 
to be read from track one, beginning at sector two, and the words read are 
to be placed in the reserved space named BUFFER, The read is to be done 
without interrupts, chaining, or comparing. 


ATI >30 
DATA LIST 


LIST DATA  BUFFER,>42,3,0 
BUFFER BSS 96 


A combination write/compare command may be issued to the disc; however, 
the read command and a compare only command are issued separately. 
Average access time to the disc is 8.7 milliseconds, When the compare is 
issued in conjunction with the write, one extra disc revolution is required. 
An average disc revolution takes 17.5 milliseconds, 


The fixed-head disc available on the 980 computer contains 32 words per 
sector. The physical structure of the disc sectors and tracks is not covered 
in this manual, but from a programming viewpoint, the disc contains 56 sec- 
tors per track, and from 32 to 1024 tracks. For purposes of disc address- 
ing only, the logical layout of the disc may be thought of as shown in figure 
2-8. 


Each even-odd track pair, tracks 0 and 1, 2 and 3, etc., requires one disc 
revolution, The optional write lockout is accomplished manually through a 
set of 16 switches and cannot be set under program control. Lockout and 
timing details not covered in this paragraph can be found in the Direct Mem- 


ory Access Channel Controller User's Manual. 


0 TRACK OY ope tae 1023 
Or) 
ee 
Ez 
S 
E 
Cc 
T 
O 
R 
| 55 | eee 
(A)129629 


Figure 2-8, Logical Layout of Fixed-Head Disc 
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2.3.3 MOVING-HEAD DISC 


The moving-head disc controller normally occupies DMAC expander port 1 
(if a DMAC expander is used) and stores status in memory locations 009Aj¢ 
and 009B 6. | 


In addition to specifying the port, the first ATI word for the moving-head disc 
controller specifies the unit number in bits 9 and 10. It also specifies that 
the controller should clear itself (bit 8=1), or acquire a command list and 
perform a subcommand (bit 8=0). A maximum of four units may be attached 
to the controller; however, in general, a command may not be issued to one 
unit while another unit is in operation. The only exception is that a command 
is accepted for one unit while another is doing an independent seek, 


The moving-head disc command list words format is shown in figure 2-9, 
The subcommand field in word 3 of the list is detailed in table 2-12, and 
table 2-13 lists the status words returned to the computer. 


WORD 1 

, | 
WORD 2 i STARTING SECTOR SECTOR COUNT 
WORD 3 & SUBCOMMAND CYLINDER ADDRESS 


WORD 4 ADDRESS OF NEXT LIST, IF CHAINING 


MEANING 
LIST BIT 1 0 
i Issue interrupt Do not interrupt 
t Chain Do not chain 
(A)129608 t Use head 1 Use head 0 


Figure 2-9, Moving-Head Disc Command List Words Format 
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Table 2-12. Moving-Head Disc Subcommands 


List Word 3 


Read data 


Read i.d. 


Compare disc and memory 


Perform independent seek 
Write data 
Write i.d. without protect 
Write i.d. with protect 


Write data protect override 


Table 2-13. Moving-Head Disc Status Word Bits 


Operation complete Not yet complete 


Write protect error ' No error 


Unit off-line line 


Data transfer error error 


End-of-disc error error 


Program error error 


Compare error error 
Status 


Word 1 


Parity error error 


ID compare error error 


Oo ON BF TH Ff WwW WN 


Device busy Not busy 


Chain list taken 


— 
ro) 


Not yet taken 
Off 


— 
— 


Write protect on 


— 
iW) 


Seek complete unit 3 Not yet complete 


_ 
Oo 


Seek complete unit 2 Not yet complete 


— 
HS 


Seek complete unit l Not yet complete 


— 
On 


Seek complete unit 0 Not yet complete 


Note: Status word 2 - address of last list executed. 
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A new disc pack must be initialized by writing an i.d. in every disc sector, 
An i,d, may be written with a protect bit set (one) or reset (zero) as speci- 
fied in the write i.d. command. If set, a write data with protect override is 
the only command which allows data to be written into a specified sector, 
From the programmers viewpoint of addressing the moving-head disc, the 
logical layout may be thought of as shown in figure 2-10. 


(A ) 129609 


Figure 2-10. Logical Layout of Moving-Head Disc 


The following programming example reads 16 sectors on moving-head disc 3, 
starting at sector 24 of head 1 on cylinder 51. Following the read, a check 
is made to determine if the operation is complete, Interrupts and chaining 
are not used. 
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LDA 
STA 
ATI 
DATA 
LDA 
SNZ 
BRU 
CPL 
SEQ 
BRU 
BRU 
STATUS DATA 
LIST DATA 
LEGAL EQU 
BUFFER BSS 


2.3.4 MAGNETIC TAPE 


=0 

*STATUS CLEAR STATUS 

>4) ISSUE ATI 

LIST ATI LIST POINTER 

*STATUS OBTAIN STATUS 

A TEST FOR CHANGE 

$-2 REPEAT IF NO CHANGE 

LEGAL TEST FOR READ COMPLETE 
CONTINUE IF COMPLETE 

ERROR BRANCH TO ERROR ROUTINE 

CONT CONTINUE 

>9A 

BUFFER ,>1810,>0133,0 

>8000 

512 


The 800-bpi, 9-track magnetic tape controller normally occupies DMAC ex- 
pander port 2 (if a DMAC expander is used) and stores status in memory lo- 
cation 009C;,¢. In addition to specifying the port, the first ATI word toa 
magnetic tape controller specifies a command in bits 8 and 9 and a unit in 
bits 11 and 12. Bits 11 and 12 are also used to reset the interface. Table 
2-14 lists the commands and unit numbers associated with the various bit 


patterns. 


Table 2-14, Magnetic Tape Command and Unit Designations 


00 
01 
10 
11 


ATI Bits ATI Bits ; 


Rewind selected unit with interrupt 
Unload selected unit with interrupt 
Rewind unit without interrupt 


Perform subcommand (acquire list) 


Reset 


Select unit 1 
Select unit 1 


Select unit 3 


00 
O01 
10 
11 


In general, if an operation is in progress on one unit, it is not possible to 
issue a command for another unit. 
accepted for one unit while another is being rewound. The magnetic tape 
command list words format is shown in figure 2-11. The subcommand field 
in word 3 of the list is detailed in table 2-15 and table 2-16 lists the status 
words returned to the computer. 


The only exception is that a command is 
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WORD 1 


WORD 2 


WORD 3 


WORD 4 


(A)129610 


LIST 


DATA ADDRESS 


CHARACTER COUNT 


* CONTROL 
BITS SUBCOMMAND 
ADDRESS OF NEXT LIST, IF CHAINING 
CONTROL BIT BREAKDOWN 

BIT 1 oO 
0 ISSUE INTERRUPT DO NOT INTERRUPT 
1 REVERSE MOTION FORWARD MOTION 
2 CHAIN DO NOT CHAIN 


Figure 2-ll, Magnetic Tape Command List Words Format 


Table 2-15, Magnetic Tape Subcommands 


List Word 3 
Bits 3-5 


Subcommand 


Read a record 
Skip a record 
Write a record 
Erase forward 


Write end-of-file 
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Table 2-16. Magnetic Tape Status Word Bits 


End-of-tape detected No end-of-tape 


Operation complete Not complete 
Write ring error No error 

2 Unit off-line On-line 

3 Controller busy Not busy 

4 DMAC parity error No error 

5 Tape parity error No error 

6 End-of-record detected No end-of-record 

Status 7 End-of-file detected No end-of-file 
Word 1 8 
9 


Beginning-of-tape de- Not detected 
tected 


Transfer error No error 


po 
© 


Rewind complete unit 1 Not complete 


a 
nN = 


Rewind complete unit 2 Not complete 


pot 
Oo 


Rewind complete unit 3 Not complete 


Command error No error 


- =_ 
om Af 


Chain list taken Not yet taken 


Note: Status word 2 - After read or write is completed or aborted, re- 
maining character count is stored; for commands other than read 
or write, address of last list executed. 


The following programming example writes a 500-character record on mag- 
netic tape unit 1 from reserved memory named BUFFER. Following the 
write, a check is made to determine if the operation is complete. Chaining 
is not used but the magnetic tape is to issue an interrupt when the write is 
complete. 


a an TF ERP PAA SS SSS SSS SSS SO SS 7 SP ATA ED SEERA, 
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LDA =0 

STA. *STATUS CLEAR STATUS 

ATI >CA ISSUE ATI 

DATA LIST ATI LIST POINTER 

LDA *STATUS OBTAIN STATUS 

SNZ A TEST FOR CHANGE 

BRU $-2 REPEAT IF NO CHANGE 

CPL LEGAL TEST FOR WRITE COMPLETE 
SEQ CONTINUE IF COMPLETE 
BRU ERROR BRANCH TO ERROR ROUTINE 
BRU CONT CONTINUE | 


STATUS DATA >9C 

LIST DATA BUFFER,500,>9000,0 
LEGAL EQU >8000 

BUFFER BSS 250 


2.4 PROGRAMMING WITH INTERRUPTS 


There are four types of interrupts in the Model 980 Computer, These inter- 
rupts, in order of priority, are as follows: internal interrupt, vectored 
interrupt option, DMAC interrupt, and data bus interrupt. It should be noted 
that no interrupts other than internal interrupts are recognized for one in- 
struction following a WDS, RDS, LSB, LSR, SSB, ora register-to-register 
instruction which has the status register as the destination register, The 
status register (SR), which is constantly referenced in this section, is cov- 


ered in detail in Model 980 Computer Assembly Language Programmer's 


Refe rence Manual, 


Certain fixed memory addresses are reserved in the computer for pre- 
assigned functions. The various reserved hexadecimal locations and their 
functions are described in table 2-17. 


2.4.1 DATA BUS INTERRUPTS 


When the computer accepts a data bus interrupt signal from an external de- 
vice, it causes a program trap to memory location 000616. A 4-bit data bus 
interrupt expander (not to be confused with the vectored interrupt option) is 
standard on the 980. It is possible to have a data bus interrupt expander for 
each of the four groups of 64 external registers addressable via the data bus, 
An interrupt expander occupies one of the 64 external addresses, When read 
by the program with an RDS instruction, it yields the true-false status of up 
to 16 interrupt signals which have been input to the interrupt expander from 
other devices. The interrupt expander generates a data bus interrupt if it 
receives an interrupt signal from one or more of its input devices, Inter- 
rupts from the interrupt expander are recognized by examining the bits for 
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Location (Hex) 


' Table 2-17. Reserved Memory 


Function 


Power restore start-up 

Internal interrupt 

DMAC eeruee 

Data bus interrupt 

Interrupts when using vectored interrupt option 
Reserved 

*Address of first logical device table entry 
*Address of first physical device table entry 
*Address of first device name table entry 
*Address of floating point package 

*Status flag for operator communication package 
*Reserved 

*MP/PIF upper limit address (absolute) 
*MP/PIF lower limit address (absolute) 
DMAC interrupt status 

Status from device on DMAC port 0 

Status from device on DMAC port 1 

Status from device on DMAC port 2 

Status from device on DMAC port 3 

Status from device on DMAC port 4 

Status from device on DMAC port 5 

Status from device on DMAC port 6 

Status from device on DMAC port 7 


*Function assigned this address by the Basic System software. 


logic one's. Bit 1 equal to one corresponds to an interrupt from the module 
in slot I01, bit 15 set to one corresponds to an interrupt from the module in 
slot 1015 (assuming internal I/O expansion). For more information, see the 


Model: 980 Computer Input/Output Manual (part no. 960964-9701). Data bus 


interrupts are lower in priority than other interrupts. Therefore, if the 
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programmer wishes to inhibit other interrupts while processing a data bus 
interrupt, the interrupt mask bits in the status register must be adjusted. 
It is not possible to inhibit internal interrupts. 


It is a common programming technique to put an SSB instruction in location 
0006 4¢. If an instruction other than an SSB or an instruction affecting the 
PC register (such as a branch or skip) is placed in location 0006,¢, then 
only the single instruction is executed. Since the PC is held fixed for exe- 
cution of the one instruction, program control is immediately returned to the 


interrupted program, 
CAUTION } 


If itis necessary to use an instruction that does 
not affect the PC at location 0006.¢; do not use 
an instruction that does not change the Memory 
Address (MA) register. The MA is used to re- 
trieve the trap instruction, so if the trap instruc- 
tion does not modify the MA, the MA will not be 
updated to the current PC value at instruction 
termination, 


Further interrupts are prohibited until after execution of one instruction sub- 
sequent to that instruction in location 0006)¢. In other words, the SSB in- 
struction and the first instruction it branches to (often an LSB), are both per- 
formed before another interrupt of any kind can be honored by the computer. 
Immediately upon completion of the SSB instruction in location 0006 1¢, and 
prior to the instruction to which it branches, the content of the SR is auto- 
matically modified to inhibit data bus interrupts (bits 4, 5, 6, 7, and 9 are 
cleared to zero). 


The data bus interrupt sequence is as follows: 


1, The instruction in location 000616 is performed. Normally, this 
instruction should be an SSB. The values stored for SR and PC are 
those which existed prior to the interrupt response, 


2. The subroutine referenced by the SSB determines which devices” re- 
quire attention, 


3. For each device requiring service, a sequence of instructions is 
executed which is peculiar to the specific device interface, Many 
devices require that the program read a 16-bit status word with an 
RDS instruction. The act of reading the status serves as an ac- 
knowledgment to the device that the program has seen the interrupt. 
The device will then remove the interrupt request, 


4, When all interrupt processing is complete, oe interrupted program 
is reentered with an LSB instruction, 


EU SNAP eh Se SS SSS Sep AS SSS Ss SSS SSS SS SS ss SSSR SS 


2-32 Digital Systems Division 


VO) 96 1961-9734 


Status register bit 7 must be on for future data bus 
interrupts to be recognized. 


NOTE 


2.4.2 DMAC INTERRUPTS 


When the computer accepts an interrupt signal from one or more DMAC de- 
vice controllers, it causes a program to trap to memory location 0004 )¢. If 
more than one device is attached to the DMAC, a DMAC expander must be 
used. The DMAC expander stores a status word at location 0096 1¢, which 
identifies the device controller(s) requiring service. In any case, the device 
controller itself will store status at a memory location as defined in table 
2-17, 


As with data bus interrupts, it is a common programming practice to put an 
SSB instruction in location 0004;¢. If an instruction other than an SSB or an 
instruction affecting the PC register (such as branch or skip) is placed in 
location 0004 1¢, then only the single instruction is executed. Since the PC is 
held fixed for execution of the one instruction only, program control is imme- 
diately returned to the interrupted program, 


If it is necessary to use an instruction that does not 
affect the PC at location 000416, do not use an in- 
struction that does not affect the MA register. The 
MA is used to retrieve the trap instruction, so if 
the trap instruction does not modify the MA, the 
MA will not be updated to the current PC value at 
instruction termination, 


Further interrupts are prohibited until after execution of one instruction sub- 
sequent to that instruction in location 0004;¢. In other words, the SSB in- 
struction and the first instruction it branches to (often an LSB), are both per- 
formed before another interrupt of any kind can be honored by the machine, 
Immediately upon completion of the SSB instruction in location 0004 ¢, and 
prior to the execution of the instruction to which it branches, the content of 
the SR is automatically modified to inhibit both DMAC and data bus interrupts 
(bits 4, 5, 6, 7, 9, and 12 are cleared to zero). 


The DMAC interrupt sequence occurs as follows: 
1, The main program is suspended, 


2. Location 009616 in memory is replaced by a word that indicates 
which device controllers require service (if the DMAC expander is 
used), 
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0096.6] a a 


Location 009616 contains a field of eight bits, ag to a7, where aj; is 
the service request bit for the device on porti. A one represents 
a service request is pending, , 

3. Locations 009816 +2i and 0099)6 + 2i are replaced with device statu 


information, if any, from the device controller. 


4, The instruction.in location 00041¢ is performed. Normally this in- 
struction should be an SSB, The values stored for SR and PC are 
those which existed prior to the interrupt response. 


5, For each device controller requiring service, a program sequence 
examines the device status, It must then perform whatever pro- 
cessing may be required. 


6. The interrupt sequence may terminate with an LSB instruction whic 
restores control to the interrupted program, 
NOTE 
Bit 12 of the status register must be turned on for 
future DMAC interrupts to be recognized, 
2.4.3 VECTORED (PRIORITY) INTERRUPT OPTION 


The methods of servicing I/O interrupts discussed thus far all involve con- 
siderable software activity just to decide which of several devices caused an 
interrupt. Only after this preliminary activity can the actual interrupt ser- 


vicing begin. For most devices this software overhead is acceptable, How- 


ever, it.may happen that'a device requires more rapid servicing than is 
attainable in this way, In such instances, the vectored (priority) interrupt 
option should be used. Use of the vectored interrupt option allows each de- 
vice to have a unique interrupt trap location. The software can then be or- 
ganized such that execution reaches a given trap location only if the asso- 
ciated device issues an interrupt. Thus, when a trap occurs, immediate 
action can be taken to service the interrupt. 


NOTE 


All standard I/O devices supplied by Texas Instru- 
ments have a preassigned interrupt structure. 
Standard Texas Instruments software does not 
make use of the vectored interrupt option. 


s 


h 
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The vectored interrupt option allows 8, 16, 24, or 32 separate trap locations, 
All interrupts have priorities, and the vectored interrupts are placed in the 
priority list as follows: 


1. Internal interrupts 
2. Optional vectored interrupts in trap locations 


000816 (highest priority) 
000A14 


00461¢ (lowest priority) 
3. Regular DMAC interrupts 
4, Regular data bus interrupts. 


After receipt of an interrupt, a lower priority interrupt is not honored until 
the original interrupt has been reset; however, an interrupt of higher priority 
is honored. Thus, while processing the first interrupt, but before resetting 
that interrupt, a second interrupt with higher priority can cause another trap 
to occur, After the second interrupt is processed, execution of an LSR in- 
struction resets the higher priority interrupt and returns control to the pro- 
gram processing the first interrupt. 


The recommended method of implementing these vectored interrupt- 
processing programs is as follows: 


& Use an SSB instruction in the trap location to branch to the interrupt- 
processing program. ; 


® Be sure that the last instruction executed in the interrupt- 
processing program is an LSR, which resets the interrupt and re- 
turns control to the interrupted program. 


If an instruction other than an SSB or an instruction affecting the PC register 
(such as branch or skip) is placed at the trap location, then only the single 
instruction is executed. Since the PC is held fixed for execution of the one 
instruction, program control is immediately returned to the interrupted pro- 


gram. 


If it is necessary to use an instruction that does not 
affect the PC at the trap location, do not use an in- 
struction that does not affect the MA register. The 
MA is used to retrieve the trap instruction, so if 
the trap instruction does not modify the MA, the 
MA will not be updated to the current PC value at 
instruction termination, 
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Further interrupts are prohibited until after execution of one instruction sub- 
sequent to that instruction at the trap location, In other words, the SSB in- 
struction and the first instruction it branches to, are both performed before 
another interrupt of any kind can be honored by the machine, Immediately 
upon completion of the SSB instruction, and prior to the execution of the in- 
struction to which it branches, the content of the SR is automatically modified 
to inhibit ordinary data bus and DMAC interrupts (bits 4, 5, 6, 7, and 12 

of the SR are cleared to zero). 


In addition to the 32 priority levels provided, the vectored interrupt option 
includes interrupt masking control and programmed interrupts. Associated 
with each vectored interrupt are three control bits that can be used to enable, 
disable, or simulate the interrupt. These three control bits for 16 inter- 
rupts are grouped together to form three 16-bit registers on the I/O data bus. 
Since the maximum number of vectored interrupts is 32, six I/O data bus 
register addresses must be allocated to the mask and programmed interrupt 
functions, The I/O data bus addresses used in conjunction with WDS and RDS 
instructions concerned with the various vectored interrupt levels are shown 
in table 2-18. 


Table 2-18, Vectored Interrupt System External Registers 


Vectored Interrupts Register | 
0 to 15 Function 


5416 Set Mask 
5516 
5616 


Vectored Interrupts 
16 to 31 


Clear Mask 


Set Interrupt 


The set mask registers are used to mask (inhibit) interrupts; the clear mask 
registers are used to unmask interrupts; the set interrupt registers are used 
to create programmed interrupts. For example, a logic one placed in bit 6 
of the data word of a WDS 5416 instruction would mask interrupt 6. The 
same data word could be used to unmask interrupt 6 with a WDS 5516, or 
create an interrupt 6 with a WDS 56, ¢- 


NOTE 


Status register bit 8 must be on for the priority 
interrupt to be recognized, 
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SECTION III 
SYSTEM PROGRAMMING CONSIDERATIONS 


3,1 INTERNAL INTERRUPT 


An internal interrupt occurs as a result of detection of imminent power fail- 
ure or detection of an undefined instruction operation code, It may also 
occur as the result of a memory parity error or memory protect/privileged 
instruction feature (MP/PIF) violation. In any case, when an internal inter- 
rupt is honored, program execution begins at location 000214. This inter- 
rupt condition is of higher priority than any other interrupt. Although the 
memory parity and MP/PIF interrupts can be masked, there is no bit in the 
status register to inhibit internal interrupts caused by illegal operation codes 
or power failure; therefore, there is no point in program execution at which 
an internal interrupt cannot occur. 


It is common programming practice to put a Store Status Block (SSB) in- 
struction in location 000216. When an internal interrupt occurs, this in- 
struction links to a program sequence which will: 


e Interrogate bit 15 of the saved contents of the status register. If it 
is a one, power failure is imminent and register contents must be 
preserved in memory (1 ms (980A), or 20 ms (980B), is available 
to perform this before execution is terminated). The status register 
bits are defined in table 3-1. 


e Interrogate bit 14 of the saved contents of the status register. If it 
is a logic one, a memory parity error was detected during execution 
of the instruction preceding the one pointed to by the saved program 
counter. 


e Interrogate bit 5 of the saved contents of the status register. If it 
is a logic one, an attempt was made to store data into, or branch 
to, a location outside the memory protect limits established, 


e Interrogate bit 6 of the saved contents of the status register. If it 
is a logic one, an attempt was made to execute one of the instructions 
privileged by PIF. 


e If none of these conditions is detected, an attempt has been made to 
execute an illegal instruction. The codes for illegal instructions 
are listed in table 3-2. 


® After all processing is complete, a Load Status Block (LSB) instruc- © 
tion may be executed which will return the machine to the interrupted 
program sequence, 
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Status 
Register 
Bits 


0-1 


10 


Table 3-1, Status Register Bit Functions 
| i 
Function 


Compare Indicators - Indicate the result of the last compare 
operation, 

00 - less than 

01 - equal to 

10 - greater than 

11 - not allowed 


Overflow Indicator - Turned on or off by those instructions 
which can cause overflow. 


Carry Indicator - Turned on or off by any add or subtract in- 
struction which can result ina carry into the sign bit ofa 
register. 


Privileged Instruction and Memory Protect. 
0 - Disabled 
1 - Enabled 


Memory Protect Address Violation - May not be set under 
program control, 

0 - No Violation 

1 - Violation 


PIF Instruction Violation - May not be set under program 
control, 

0 - No Violation 

1 - Violation 


Data Bus Interrupt Control 
QO - Disabled 
1 ~ Enabled 


Vectored Interrupt Feature 
0 - Disabled 
1 - Enabled 


PIF Lower Limit Address Bias 
0 - Disabled 
1 - Enabled 


Index Control 
0 - Post Indexing 
1 - Pre-indexing 
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Table 3-1, Status Register Bit Functions (Continued) 


Status 
Register Function 
Bits 


Memory Parity Error Interrupt Control 
0 - Disabled 
1 - Enabled 


DMAC Interrupt Control 
0 - Disabled 
1 - Enabled 


Not Used 


Memory Parity Error Indicator - May not be set under pro- 
gram control, 

0 - No Error 

1 - Error 


Power Fail Indicator - 1 ms (980A) or 20 ms (980B) warning 
that power failure is imminent, May not be set under program 
control, 


0 - Power Up 
1 - Power Failure Imminent 


If an instruction other than an SSB or an instruction affecting the PC register 
(such as a branch or skip) is placed in location 00021¢, then only the single 
instruction will be executed, Since the PC is held fixed for execution of the 
one instruction.only, program control is immediately returned to the inter- 


rupted program, 


If it is necessary to use an instruction that does not 
affect the PC at location 0002 ;¢, do not use an in- 
struction that does not affect the MA register. The 
MA is used to retrieve the trap instruction, so if 
the trap instruction does not modify the MA, the 
MA will not be updated to the current PC value at 
instruction termination. 


Further interrupts are inhibited until after execution of one instruction sub- 
sequent to that instruction in location 0002,,. In other words, the SSB in- 
struction and the first instruction it branches to. will both be performed be- 
fore another interrupt of any kind can be honored. When an internal interrupt 
is recognized, bits 4, 5, 6, 7, 8, 9, 12, 14 and 15 of the status register are 
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Table 3-2. Illegal Instruction Codes 


Instruction Bits 
7 8 10 «#11 


ene 2 DO De <0? De > De > De i> as > > > es a o> ee a ee 


6 
X 
X 
0 
0 
] 
1 
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1 
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X 
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X = DON'T CARE (0 or 1) 


cleared to zero after execution of the instruction in the trap location, If the 
machine traps because of an illegal operation, and an illegal instruction is 
in location 000216, the machine is halted. 


3.2 POWER FAILURE PROTECTION 


The 980 is protected against loss of data due to power failure. An input 
power detector allows 1 millisecond (980A), or 20 milliseconds (980B), of 
operation when power failure is imminent and then disables the computer and 
the memory initiate circuit. The operating program is warned of the power 
failure condition via an internal interrupt. Subsequently, when power is re- 
stored, the operating program is automatically started at memory location 
zero. When power is initially applied to the computer, the situation is in- 
ternally analogous to a power-restored condition, so program execution 
automatically starts at memory location zero. | 
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It is a common programming technique to put an LSB instruction in location 
000016. The LSB branches to a sequence of instructions which restores the 
machine environment that existed prior to power loss. Since a power loss 
clears all DMAC controllers and operations in progress are not completed, 
care must be taken in restarting DMAC devices. The Basic System, if used, 
includes routines to handle the power-restore/start-up condition, 


3.3 MEMORY PARITY ERROR DETECTION 


The 980 performs a check of parity on all data transferred from memory. 
In the event a parity error is detected, one of two possible options occurs: 


e If bit 11 of the status register (parity error mask) is a zero, the 
parity error is ignored, . : 


® If bit 11 of the status register is a one, bit 14 of the status register 
is set to a one, and an internal interrupt is generated. 


The first option is usually not an acceptable mode of operation, because it 
does not even allow a count of parity errors to be kept. The second option 
allows the user to attempt a recovery, to continue in a degraded mode of 
operation, or to terminate his program. _ 


3.4 MEMORY PROTECT/PRIVILEGED INSTRUCTION FEATURE (MP/PIF) 


When program execution is under direction of a monitor program, itis de- 
sirable to restrict a user program in several ways in order to protect the 
monitor as well as the balance of the operating system. These restrictions 
are implemented on the 980 through use of the MP/PIF which prevents a 
user program from: 


® Reading, writing, or branching into protected memory. 
e Changing the status register. 

e Performing I/O. 

e Bringing the computer to an idle, 


To enable the MP/PIF, it is first necessary to load the MP/PIF lower limit 
and upper limit registers that define the limits within which execution will 

be constrained, Both registers are loaded by use of the WDS instruction just 
as if the MP/PIF registers were external to the computer. Register address 
zero defines the lower limit and register address one defines the upper limit. 
These boundary locations and all memory outside of the boundaries are pro- 
tected by the MP/PIF feature. The monitor then enables MP/PIF through 
use of an LSB instruction that sets bit 4 of the status register. Control can 
now be transferred to the user program. 
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3.5 PROGRAM RELOCATION FEATURE 


The lower limit register used by the MP/PIF is also used by ie program 
relocation feature. If the monitor sets bit 9 of the status register, at the 
time control is transferred to the user program, the contents of the lower 
limit register plus one is added into the address calculations for each mem- 
ory access. The effect of this is that a program may be loaded anywhere in 
memory, but the program operates as though it were loaded starting at loca- 
tion 000016. 


For example, suppose a program is assembled as an absolute program with 
origin at location 0000;¢. Also, suppose that the entry point to the program 
is location 002016, and that it is convenient for the monitor to load the pro- 
gram at location 100016. The monitor loads the program starting at 1000]¢, 
places OF FF ¢ in the lower limit register, and performs an LSB instruction 
to transfer to the program. The LSB must set bit 9 of the status register 

and load the program counter with 0020;¢. Note that although the instruction 
executed is at 10201¢, the program counter contains 0020,¢. If, for instance, 
a trap were to occur, the SSB at the trap location would save the value 0020 )¢ 
for the program counter, not 1020 1¢. 
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SECTION IV — 
MODEL 733 ASR/KSR PROGRAMMING CONSIDERATIONS 


4,1 GENERAL INFORMATION 


This section contains the information necessary to program all I/O opera- 
tions involving the Texas Instruments 733 ASR/KSR data terminals, Included 
in this section is a discussion of character format and transmission rates, 

a detailed breakdown of control, status, and data interface lines, and pro- 
gramming examples involving the teleprinter, keyboard, and cassette por- 
tions of the data terminal, 


The 733 ASR/KSR data terminals communicate with the Model 980 Computer 
on a character-by-character basis via the Full Duplex EIA Communications 
Module. The communications module plugs into an 1/O data bus port of the 
computer and connects to the 733 ASR/KSR data terminal with a standard 30 
foot cable. In this configuration, the communications module performs both 
the data synchronization and formatting necessary for the computer to inter- 
face with the 733 ASR/KSR data terminal, The logic circuits on the com- 
munications module perform all the functions required to serially transmit 
and receive data while supplying a variety of status indicators and control 
signals to the computer. The transmit and receive circuits on the communi- 
cations module operate independently of one another (full-duplex operation), 
and each is able to convert between the computer TTL logic levels and the 
733 ASR/KSR EIA levels. 


4,1,1 TRANSMISSION RATE AND CHARACTER FORMAT 


The 733 ASR (printer with dual cassettes) allows data transfer to and from 
the cassettes ata rate of 1200 baud. The 733 ASR in printer mode operates 
at an effective rate of only 300 baud (1200 baud with a programmable delay). 
All 733 KSR operations are at 300 baud. Synchronous operation at 300 baud 
is maintained by creating an effective 300-baud transmission rate comprised 
of an 8.33 millisecond character time followed by a 25,0 millisecond mini- 
mum delay time. On the communications module, this is accomplished by 
setting the Write Request Delay (WRD) bit (WDS control bit 9) to a logic one 
prior to initiating transmission of an USASCII character data string. It is 
necessary that this bit be a logic zero for direct cassette communication at 
1200 baud. 


Regardless of the baud rate, an USASCII character will be represented at 
the communications module/733 ASR/KSR interface as shown in figure 4-1. 
The serial bit pattern consists of a start bit, seven data bits with the least 
significant bit first, a parity bit, and a stop bit. The seven bits of data 


4-1] Digital Systems Division 


0) 96196 1-9734 | 


SPACING SPACING 
eo ee it es ee es 
| & | | | [ [ _ | = | 
~leileatl wf«l ole lfl £1 8! 
= - Ee = - . = re ea . I 
a ee ee 
bl algl gigt gl gi gl Els y 
po toto yor po ob st et 
i) eae ee eae es ee CY Ge 


s 


oma ater BIT TIME 


CHARACTER TIME 


300-BAUD 1200~BAUD 
CHARACTER TIME 33.3ms 


Figure 4-1, 733 ASR Character Format and Timing 
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comprise the limited USASCII character code (refer to Appendix A) used in 
the computer, The start and stop bits surrounding the USASCII character 
are used for timing purposes at the communications module/733 ASR/KSR 


interface, 


4,1.2 COMMUNICATIONS MODULE OPTIONS 


The communications module has a group of Single Pole Single Throw (SPST) 
switches that affect the communications module interface with both the com- 
puter and the 733 ASR/KSR terminal, The switches are located on the com- 
ponent side of the module board in two Dual-Inline- Packages, as shown in 

figure 4-2. The switch-selectable options include the I/O data bus address 
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POLE 1 


SWITCH 1 


POLE 7 


POLE 1 


POLE 7 


(A)128347 


Figure 4-2. Communications Module Switch Locations 


assigned to the communications module, the transmit and receive baud rate, 

. word length, and stop bit configuration associated with the interfacing data 
terminal, and parity bit control. Each of these options is explained in more 
detail in the following list: | 


e Module Address Selection - The communications module must be 
assigned to one of the 64 available I/O data bus addresses. The 
selected address should not conflict with the address of any other 
peripheral device on the I/O data bus, and software must be aware 
of the selected address. The available addresses range from 0016 
to 1F4¢ and 40)¢ to 5F4¢, with 05)¢ used as the standard address 
by Texas Instruments furnished software. Table 4-1 lists the 
switch poles used in the address selection and the logic value of the 
two pole positions, 
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Hex Digit 
of Address 


Baud Rate Selection - The transmit and receive baud rate is deter- 
mined by switch $2, poles 1 to 3, as listed in table 4-2. The stan- 
dard rate is 1200 baud for the 733 ASR and 300 baud for the 733 KSR, 


Parity Selection - Poles 4 and 5 of switch S2 are used to select even 
or odd parity generation, or no parity, as listed in table 4-3, Odd 
parity is standard with the 733 ASR/KSR data terminals, 


Word Length Selection - The word length used in communications 
between the computer and data terminal may be set to 5, 6, 7, or 8 
bits (in addition to parity), The number of bits is determined by 
poles 6 and 7 of switch S2 as listed in table 4-4, The 7-bit word is 
standard with the 733 ASR/KSR data terminals, 


Stop Bit Selection - The number of stop bits is switch selectable, 
Pole 1 of switch S1 determines the number of stop bits as listed in 
table 4-5, 


Table 4-1, Communications Module Address Selection 


WDS/RDS Logic 1 
Word 1 -Bits* Position 


Logic 0 
Position 


Switch Sl Pole 


2 (A09) 
3 (Ald) 


4 (A12) 
5 (Al3) 
6 (A14) 
7 (A15) 


NORE! NON! 


*Bit 10 of word 1 is used to specify WDS or RDS, and is assumed to be 
zero in developing the MSD of the module address, 


4,2 PROGRAMMING INFORMATION 


The 733 ASR/KSR data terminal interfaces with the computer via one I/O | 
data bus external register, The single register, normally addressed at 
0514 by Texas Instruments furnished software, handles the transmission of 
data, command, and status information between the computer and 733 ASR/ 
KSR data terminal. The following paragraphs describe the data word for- 
mats associated with the 733 ASR/KSR WDS and RDS instructions (including 
subcommands), and provide programming examples illustrating their use. 
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Table 4-2. Baud Rate Selection 
| Switch S2_ 
Pole 1 (R/A) Pole 2 (R/B) Pole 3 (R/C) 


NON! | | 
NON! 
NORF'! 


Table 4-3, Parity Selection 


Switch S2 Pole 
Pole 4 (PI) Pole 5 (PS) 


wea 
Odd Parity 


NON!!. 


4.2.1 733 ASR/KSR WDS DATA WORD DESCRIPTION 


"OFF" 


NON! 


NORFF!! 


NON! 


NON! 


"ORF!" 


*4800 Baud for E15-E16 (Standard) 
600 Baud for E16-E17 


Parity 
Selection 


Parity 
Inhibited 


The 16-bit WDS data word is used by the programmer to issue commands, 
subcommands, and USASCII characters to the data terminal. The format 
of the WDS data word is shown in figure 4-3. Note that when bit 7 of the 
data word is set, bits 8 through 15 of the data word contain additional con- 
trol information; when bit 1 of the data word is set, bits 8 through 15 of the 
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Table 4-4, Word Length Selection 


Switch S2 Pole 


Number of , 
Data Bits Pole 6 (WL2) Pole 7 (WL1) 
NON! 
NOFF! 


Table 4-5, Stop Bit Selection 


Stop Bit Switch S1 
Selection Pole 1 (STB) 


BIT 8 9 10 11 12 13 14 15 
INTERRUPT] WRITE NOT DATA REQUEST oT 
ENABLE | REQUEST USED TERM TO: USED 
DELAY (ZERO) | READY SEND (ZEROS) 


: CON=1 
BIT (¢) 1 2 3 4 5 6 7 
WRITE CLEAR CLEAR 
EAD DATA NEW WRITE NOT USED CONTROL 
REQUEST READY STATUS | REQUEST 
CRR WDR CNS CWR CON 


(A)129613 


Figure 4-3, 733 ASR/KSR WDS Data Word Format 


4-6 Digital Systems Division 


is 961961-9734 | 


data word contain a USASCII character, The character may represent a sub- 
command or data to be written to the data terminal, The two types of sub- 
commands are described in the next paragraph. The individual bits of the 
WDS data word are described in the following list: 


® Clear Read Request (CRR) - A logic one in bit 0 clears the Read Re- 
quest (RREQ) flag and-the associated interrupt (if enabled) on the 
communications module. The RREQ flag is described in bit 0 of the 
RDS data word format. A logic zero in bit 0 causes no action, 


e Write Data Ready (WDR) - A logic one in bit 1 loads the USASCII 
character in bits 8 through 15 in the transmit buffer register on the 
communications module. This action initiates the transmission se- 
quence to the data terminal, A logic zero in bit 1 causes no action, 


® Clear New Status (CNS) - A logic one in bit 2 clears the New Data 
Set Status (DSS) flag and the associated interrupt (if enabled) on the 
communications module. The DSS flag is described in bit 2 of the 
RDS data word format. A logic zero in bit 2 causes no action. 


e Clear Write Request (CWR) - A logic one in bit 3 clears the Write 
Request (WREQ) flag and the associated interrupt (if enabled) on the 
communications module. The WREQ flag is described in bit 1 of the 
RDS data word format. A logic zero in bit 3 causes no action, 


r) Not Used - Bits 4, 5, and 6 of the WDS data word are not used by 
the 733 ASR/KSR data terminal. 


6 Control (CON) - A logic one in bit 7 indicates to the communications 
module that bits 8, 9, 11, and 12 contain control information. A 
logic zero in bit 7 causes no action. 


If bit 1 of the WDS format is set, bits 8 through 15 contain a USASCII char- 
acter with bit 8 the MSB and bit 15 the LSB, If bit 7 of the WDS format is 
set, the following controls are output to the communications module: 


e Interrupt Enable (INT) - A logic one in bit 8 enables the communi- 
cations module to issue an I/O data bus interrupt when a read re- 
quest, write request, or data set status change occurs. The inter- 
rupt is cleared by clearing the condition that caused the interrupt. 
A logic zero in bit 8 inhibits the communications module interrupt. 


® Write Request Delay (WRD) - A logic one in bit 9 delays the com- 
munications module from issuing a write request (bit 1 of the RDS 
data word format) until 33 milliseconds after loading the transmit 
buffer register. Normally, a write request is issued when the 
transmit buffer register becomes empty. This delay option is used 
to create an effective 300-baud serial transmission rate when ad- 
dressing the teleprinter portion of the 733 ASR/KSR data terminal 
through the 1200-baud interface. The delay results in a one- 
character print period of 33.33 milliseconds, equaling the 30 
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character per second print rate of the 733 teleprinter, Figure 4-4 
shows the timing relationships between the 300-baud and 1200- baud 
transmission rates, A logic zero in bit 9 inhibits the delay action, 


e Data Terminal Ready (DTR) - A logic one in bit 11 maintains the 
DTR circuit on the communications module in the ''ON'' condition, 
The DTR circuit drives the Data Set Ready (DSR) input line of the 
733 ASR/KSR data terminal to enable the transmit and receive ca- 
pabilities of the data terminal. A logic zero in bit 11 maintains the 
DTR circuit in the 'OFF'" condition. 


e Request to Send (RTS) - A logic one in bit 12 maintains the RTS 
circuit on the communications module in the ''ON'' condition, The 
RTS circuit drives the Data Carrier Detect (DCD) input line of the 
733 ASR/KSR data terminal to enable the data terminal to accept 
USASCII characters from the communications module, A logic zero 
in bit 12 maintains the RTS circuit in the "OFF" condition, 


e Not Used - Bits 10, 13, 14, and 15 of the WDS control data word 
are not used by the 733 ASR/KSR data terminal, 


4,2.2 733 ASR SUBCOMMANDS 


The 733 ASR subcommands, or Remote Device Control (RDC) functions, 

each consist of a USASCII character placed in the least significant half of the 
data word associated with a WDS instruction. These control instructions are 
used by the programmer to perform such mechanical tasks as rewind and load 
cassettes, 


The RDC functions are basically divided into two categories: (1) those acti- 
vated by receipt of a single USASCII control character and (2) those activated 
by receipt of the non-printable ''DLE' character followed by a second prede- 
termined USASCII character code. The first category is known as the Auto- 
ratic Device Control (ADC), or single-character subset, while the second 
category is known as the DLE, or two-character subset. The two categories 


8.33"s-g@e «a——— 25ms DELAY 


300 BAUD 
CHARACTER - 
TRANSMISSION WREQ=1 
(30 cps ) 


8.33ms5 
1200 BAUD 
CHARACTER 
TRANSMISSION 
(A)129614 WREQ=1_s . WREQ=I1 WREQ=1 


Figure 4-4, 300-Baud/1200-Baud Timing Relationships 
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Table 4-6, Remote Device Control Functions 


Single- Character Functions (AD C). 


USASCII 
Function - Hex Code Character 


Playback On/Keyboard Off (No busy bit >11 DCl 


necessary) 
Record On/Printer Off . >12 DC2 
Playback Off/Keyboard On >13 DC3 
Record Off/Printer On  >14 DC4 


Two-Character Functions (''DLE'") 


USASCII 
Character 


Function 


Rewind Cassette l >31 1 
Rewind Cassette 2 >32 fe 
Load Cassette 1 >33 3 
Load Cassette 2 >34 4 
Cassette 1 In Record, 2 In Playback >35 5 
Cassette 2 In Record, 1 In Playback >36 6 
Block Forward . . S37 7 
Block Reverse >38 8 
Printer On (Non-Operable) . >39 9 
Printer Off (Non-Operable) >30 0 
Automatic Device Control (ADC Above) . 3A : 
On - 
Automatic Device Control (ADC Above) - >3B : 
Off 


Request Status Information 


of RDC functions and their activation codes are listed in table 4-6. It should 
be noted that the RDC logic circuitry automatically disables the teleprinter 
portion of the 733 ASR from printing the first character received after the 
"DLE" character code. This ensures that all of the two-character functions 
are, in effect, treated in the same manner as any non-printable USASCII con- 
trol character, suchas those in the ADC (single-character) category. 


The Command Status Character, shown in figure 4-5, is transmitted by the 
733 ASR data terminal to the computer in response to the RDC request status 
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STATUS CHARACTER BITS 


Figure 4-5, Command Status Character Bits 


command (command ''>3C'' of table 4-6). The status character bits, num- 
bered from 7 (MSB) to 1 (LSB), correspond to bits 9 through 15 at the com- 


puter interface, 


Each of the bits is described in the following list: 


Playback Ready (Bit 1) - A logic one level in this bit position indi- 
cates the playback cassette is ready to be enabled with the ADC 
playback on (''DC1") or the RDC block forward ('"'DLE", ''7'') func- 


tion, 


In the event that a logic zero level is found in this bit posi- 


tion, one or more of the following conditions must exist: 


1, 
Ze 
3. 
4, 


Cassette door open or cassette not in place. 
Cassette tape on clear leader, 
Playback not in line mode. 


Rewind or load operation still in execution, 


Playback Error (Bit 2) - A logic one in this bit position indicates 

that a playback error has been discovered while an 86 character 
block of data was being read from the cassette tape. In this event, 
the transmission of any characters from the block of data is inhibited 
until the error status is reset to a logic zero level, The RDC block 
reverse command is normally utilized in the recovery of a playback 


error. 


Only block reverse is capable of clearing the error status. 


BOEO!1 (Bit 3) - A logic one level in this bit position indicates that 
cassette 1 is positioned on clear leader at either the beginning or the 
end of the tape. Note that either condition automatically inhibits the 
RDC rewind command function, 


BOEO2 (Bit 4) - The description of this bit position is identical to 
that for BOEO], except that the information applies to the position 
of cassette 2, 
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® Record Ready (Bit 5) - A logic one level in this bit position indicates 
that the record cassette is ready to be enabled with the ADC record 
on (''DC2"') function. Ifa logic zero level is found in this bit posi- 
tion, one or more of the following conditions must exist: 


1, Cassette door open or cassette not in place, 
2. Cassette tape on clear leader, 

3. Record not in line mode, 

4. Rewind on load operation still in execution. 
5. Record enable tab removed. 


@ Printer Ready (Bit 6) - A logic one level in this bit position indi- 
cates that the teleprinter is enabled and ready for normal operation, 
If a logic zero level is found in this bit position, one or both of the 
following conditions must exist: | 


Ls Printer not in line mode, 


2. Printer is disabled as a result of the ADC record-on 
function (''DC2"'), 


@ Bias Bit (Bit 7) - This bit position will always be held to a logic one 
level to ensure that the status character is not an element of the 
USASCII control character subset, 


The following list describes both the single-character and double-character 
RDC commands: 


® Playback On/Keyboard Off (DC1) - The ''playback on'' function ini- 
tiates the reading and transmitting of characters from the cassette 
tape, provided the playback cassette is loaded and ready as indi- 
cated by bit 1 of the status character. This function is performed 
only on data received over the communication lines or generated 
in the terminal's local loop. 


® Record On/Printer Off (DC2) - The ''record on'' function initiates 
the receipt and recording of characters onto the cassette tape, pro- 
vided the record cassette is loaded and ready as indicated by bit 5 
of the status character. Upon receipt of ''DC2", the record function 
is turned on and the printer enters a print cycle regardless of the 
fact that ''DC2'' is a non-printable character, The ''DC2" character 
is neither entered into the hardware buffer nor recorded on the tape. 
This function is performed only on data received over the communi- 
cation lines or generated in the local loop. 


® Playback Off/Keyboard On (DC3) - The "playback off"! function ter- 
minates the reading and transmitting of characters from the cassette 
tape under the condition that if the ''DC3'' (X-OFF) code is on the 
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playback tape then one more character after the ''DC3" will be 
played back before the cassette is acutally turned off, This function 
is performed on both transmitted and received data as well as data 
generated in the terminal's local loop. ''DC3'' and ''RUB OUT" (de- 
lete) are the last two codes, respectively, entered by the terminal 
operator to conclude each source line. 


Record Off/Printer On (DC4) - The ''record off'' function terminates 
the receipt and recording of characters onto the cassette tape. 

Upon receipt of the ''DC4"' character, the record function is turned 
off and the printer is turned on, however, a print cycle is not 
entered as is the case with the ''DC2'' command, The ''DC4'' char- 
acter is then entered into the hardware record buffer and all suc- 
ceeding characters sent to the printer (including the ''DC2" char- 
acter) are also ''overpunched'"' on the ''DC4" character in the buffer. 
The resulting characteé (usually a. TF 16 delete) i is recorded on the 
tape along with the data in the normal manner (i.e., whena 
carriage-return is received in the Line format mode of operation or 
when 86 characters have been entered into the buffer in either the 
Line or Continuous format modes of operation). Note that a string 
of data is not automatically recorded onto the cassette tape simply 
by issuance of the ''record off'' command, This function is per- 
formed only on data received over the communication lines or gen- 
erated in the local loop. 


Rewind Cassette 1 (DLE, 1) - Upon receipt of the rewind command 
code (under the condition that the cassette tape is not already on 
clear leader at either end of the tape), cassette 1 will slew in the 
reverse direction until clear leader is sensed at the beginning of 

the tape. From the time that the cassette begins performing the re- 
wind operation, either bit | or bit 5 of the status character (depend- 
ing on whether cassette 1 is in the playback or record mode re- 
spectively) will be held to a logic zero, indicating the cassette is 
not ready. When the rewind operation has been completed, bit 3 of 
the status character will become a logic one indicating the presence 
of the clear leader, Only the issuance of a load cassette 1 command 
will reset the appropriate bits of the status character and ready the 
cassette. Note that the cassette cannot be remotely rewound once 

it has entered the clear leader at the far end of the tape, 


Rewind Cassette 2 (DLE, 2) - The description of this command code 
is identical to that for rewind cassette 1, except that bit 4 of the 
status character indicates the presence of clear leader on cassette 
2. 
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* Load Cassette 1 (DLE, 3) - Upon receipt of the load command code 
(under the condition that the clear leader is sensed at the beginning 
of the tape), cassette 1 will advance the tape until the beginning of 
tape marker is sensed. During the time that the load operation is 
being performed, either bit l or bit 5 of the status character (de- 
pending on whether cassette 1 is in the playback or record mode, 
respectively) will be held to a logic zero, indicating that the cas- 
sette is not ready. Upon completion of the load operation, the appro- 
priate bit of the status character will become a logic one, indicating 
the cassette is ready to be enabled with either the ''record on" or 
the ''playback on'' command code, 


@ Load Cassette 2 (DLE, 4) - The description of this command code 
is identical to that for load cassette 1, except that bit 4 of the status 
character is the bit which indicates the presence of clear leader on 
cassette 2. 


e Cassette 1 In Record, 2 In Playback (DLE, 5) - Upon receipt of the 
appropriate two-character command code, cassette 1 will be placed 
in the record mode of operation and cassette 2 will be placed in the 
playback mode. This operation will be performed regardless of the 
state of any bits in the status character, although its execution may 
change the state of several bits in the status character. 


® Cassette 2 In Record, 1 In Playback (DLE, 6) - The description of 
this command code is similar to that for cassette l in record, 2 in 
playback, except that the result of this command code is the com- 
plement of that description, 


® Block Forward (DLE, 7) - Upon receipt of the block-forward com- 
mand code (under the condition that the playback ready bit of the 
status character is true), the cassette controller will read an 86- 
character block of data from the playback cassette and will initiate 
transmission of the resulting string of USASCII characters. ‘Trans- 
mission of the string will continue until all 86 characters have been 
exhausted or until a playback-off (''DC3"') character code is en- 
countered in the transmission, In the event that transmission is 
terminated by occurrence of the ''DC3'' character on the tape, the 
block forward command code may be reissued to initiate trans- 
mission of those characters remaining in the 86-character block of 
data originally read from the tape, The block forward command 
code may have to be reissued several times, depending on the num- 
ber of ''DC3'' characters in the original 86-character block of data, 


In the event that transmission was never initiated because a play- 
back error was discovered while reading the 86-character block 
from the cassette tape, this command code will cause the following: 
the playback error bit of the status character (bit 2) will be reset; 
the block containing the error will be bypassed; a new 86 character 
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block will be read from the cassette tape; transmission of the new 
block will be initiated, provided that the new block did not also con- 
tain a playback error, 


@ Block Reverse (DLE, 8) - Upon receipt of the block-reverse com- 
mand code (under the condition that the playback ready bit of the 
status character is true), the cassette controller will rewind the 
tape one full block of data (86 characters) and clear the contents of 
the hardware read buffer. In the event that this command code is 
received while the playback error bit of the status character (bit 2) 
is true, this command will also reset the error flag, thereby pre- 
paring the block to be reread. 


@ Printer-On (DLE, 9) - This RDC command code is non- operable 
since this function has already been automatically included as a 
part of the ADC record-off command code (''DC4"'), 


® Printer-Off (DLE, 0) - This RDC command code is non-operable 
since this function has already been automatically included as a 
part of the ADC record-on command code ("'DC2"), 


e Automatic Device Control On (DLE, :) - This command enables the 
playback on/off ("'DC1''/'"'DC3") and record on/off (''DC2''/''DC4") 
ADC commands to become effective after having been disabled with 
the ''ADC OFF" command. 


® Automatic Device Control Off (DLE, ;) - This command disables 
the playback on/off (''DC1/''DC3") and record on/off ('!'DC2"'/''DC4"'') 
ADC commands, It is particularly useful for recording the ''DCl1"' 
through 'DC4" characters onto a cassette tape without affecting the 
operation of the 733 ASR data terminal, 


® Request Status (DLE,< ) - Upon receipt of the request status com- 
mand code, the 733 ASR data terminal will transmit the specially 
configured USASCII Command Status Character to the computer 
interface, This character is particularly useful in determining 
when such mechanical functions such as rewind and load operations 
are completed, 


4.2.3 733 ASR/KSR RDS DATA WORD DESCRIPTION 


The 16-bit RDS data word is used by the programmer to read status and 
USASCII characters from the data terminal. The format of the RDS data 
word is shown in figure 4-6, Note that when bit 0 of the data word is a logic 
one, bits 8 through 15 of the data word contain an USASCII character; when 
bit 0 of the data word is a logic zero, bits 8 through 15 of the data word con- 
tain additional status information, The only exception to this generality on 
bit 0 of the data word occurs following a request status subcommand to the 
733 ASR. Inthis case, the Read Request flag (bit 0 of the RDS data word) 
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Figure 4-6. 733 ASR/KSR RDS Data Word Format 


is set to indicate that the cassette Command Status Character has been 
loaded in bits 9 through 15 of the data word. The individual bits of the RDS 
data word are described in the following list: 


e Read Request (RREQ) - A logic one in bit 0 indicates that a char- 
acter has been transferred from the data terminal to the communi- 
cations module, and is available to the computer in bits 8 through 
15 of the data word. The set RREQ flag will cause an 1/O data bus 
interrupt if the communications module interrupt is enabled (via bit 
8 of the WDS data word). A logic zero in bit 0 indicates that no 
character has been read from the data terminal and bits 8, 9, and 
15 of the data word contain status information. 


e Write Request (WREQ) - A logic one in bit 1 indicates that the 
transmit buffer register on the communications module is empty, 
and is ready to accept a new character from the computer for trans- 
mission to the data terminal. The set WREQ flag will cause an I/O 
data bus interrupt if the communications module interrupt is en- 
abled (via bit 8 of the WDS data word). A logic zero in bit 1 indi- 
cates that the communications module is not requesting a new char- 
acter. This may be due to a full transmit buffer register or the 
clearing of the WREQ flag following the transmission of the last 
USASCII character ina data string. 
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New Data Set Status (DSS) - A logic one in bit 2 indicates that a 
change of state has occurred in the Data Set Ready (DSR) signal 
from the 733 ASR/KSR. This usually means the keyboard ON-LINE/ 
LOCAL switch on the 733 ASR/KSR has been repositioned. The set 
DSS flag will cause an I/O data bus interrupt if the communications 
module interrupt is enabled (via bit 8 of the WDS data word). A 
logic zero in bit 2 indicates that no change has occurred in the DSR 
signal, 


Read Framing Error (RF £) - The RFE signal is valid only as long 
as the Read Request flag of the interface is set. A logic one in bit 

3 indicates that improper character framing was detected by the 
communications module receive circuitry. This condition may be 
caused by an improperly selected baud rate or an erroneous number 
of stop bits. The RFE flag is cleared when another character is 
properly received, provided that a Clear Read Request has been 
previously issued (bit 0 of WDS data word). A logic zero indicates 
that the character was properly received with respect to both timing 
and stop bit considerations, 


Read Timing Error (RTE) - The RTE signal is valid only as long as 
the Read Request flag of the interface is true set. A logic one in 
bit 4 indicates that the communications module received another 
USASCII character from the 733 ASR/KSR before the computer 
completed loading the previous character, In this event, the com- 
munications module replaces the previous character with the one 
most recently received and, as such, this flag indicates that one or 
more characters have been lost in transmission. The RTE flag is 
cleared when another character is properly received, provided that 
a Clear Read Request has been previously issued (bit 0 of WDS data 
word). A logic zero indicates that no characters have been lost in 
transmission, 


Read Parity Error (RPE) - The RPE signal is valid only as long as 
the Read Request flag of the interface is set. A logic one in bit 5 
indicates that improper parity generation was detected by the com- 
munications module receive circuitry. Both the communications 
module and the 733 ASR/KSR data terminals expect an odd parity 
bit generation and, as such, this flag indicates that the received 
character contained an even parity bit. The RPE flag is cleared 
when another character is properly received, provided that a Clear 
Read Request has been previously issued (bit 0 of WDS data word), 
A logic zero indicates that the character was properly received 
with an odd parity bit. 


Not Used - Bits 6 and 7 of the RDS data word are not used by the 
733 ASR/KSR data terminal, 
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If bit 0 of the RDS data word (RREQ) is a logic one, bits 8 through 15 contain 
an USASCII character with bit 8 the MSB and bit 15 the LSB. If bit 0 of the 
RDS data word is a logic zero, the following status data is returned to the 
computer: 


e Transmit Buffer Register Loaded (XBL) - A logic one in bit 8 indi- 
cates that the communications module transmit buffer register is 
presently loaded with a USASCII character and unable to accept 
another. A logic zero indicates that the USASCII charcter has been 
transferred to the transmit shift register and that the transmit buf- 
fer register is now ready to accept another USASCII character. 


e Transmit Shift Register Load (XRL) - A logic one in bit 9 indicates 
that the communications module character is in process of being 
serially transmitted to the 733 ASR/KSR data terminal. A logic 
zero indicates that the module transmit shift register is empty and 
that no serial transmission is presently in progress, 


e Not Used - Bits 10 through 14 of the RDS status data word are not 
used by the 733 ASR/KSR data terminal. Bits 10, 11, and 12 are 
wired to logic zero's and bits 13 and 14 are wired to logic one's, 


© Data Set Read (DSR) - A logic one in bit 15 indicates that the 733 
ASR/KSR data terminal is in the on-line mode of operation, This 
circuit is driven by the Data Terminal Ready output line of the 733 
ASR/KSR data terminal and is maintained in the ''ON'" condition as 
long as the 733 ASR/KSR keyboard ON-LINE switch is engaged and 
the ASR-to-computer connection is ‘maintained. 


4,2.4 PROGRAMMING EXAMPLES 


The programming examples in the following paragraphs include writing to 
both the teleprinter and cassette portions of the 733 ASR, reading from both 
the keyboard and cassettes, and issuing subcommands,. All of the examples 
address I/O data bus register 05,¢ in conjunction with the 733 ASR/KSR 
data terminal. 


The busy bit test, associated with both WDS and RDS instructions, should 
not be used when writing a data word consisting entirely of control data or 
reading a data word consisting entirely of status data, In addition, the busy 
bit test should not be used with the first WDS instruction in a program or 
when writing the DC1 subcommand (playback on) to the terminal, These re- 
strictions make it advantageous to make the first WDS instruction one that 


writes all control data or issues the DCl subcommand, If this is not possible, 


the busy bit test can be replaced with a check on the Write Request (WREQ) 
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flag to determine when the WDS data word character bits have been accepted 
by the data terminal, The following example illustrates this alternate meth- 


od: 

LDA =>12 SEND DC2 COMMAND (RECORD-ON CHARACTER) 
@IOR =>5000 LOAD DATA, CLR WRITE REQ 
WDS 5 WRITE TO ASR FROM REG A 
DATA 0 NO BUSY BIT (1ST WDS) 
RDS 5 READ STATUS (BIT 0 = 0) 

Replaces | DATA 0 REGISTER A | 

Busy Bit } TABO 1 TEST BIT 1 (WREQ=1?) 
BRU $3 LOOP IF WREQ = 0 


In general, the guidelines listed below should be followed in programming 
the 733 ASR/KSR data terminal: 


e If the ASR portion of the data terminal is the subject of the program, 
issue the appropriate subcommand(s) (refer to table 4-6) to ready 
the desired cassette for the I/O data transfer, 


e If the busy bit test is required on the first WDS instruction of the 
program, use the alternate method shown in the previous example. 


e Before each WDS instruction to write an USASCII character, clear 
the Write Request (WREQ) flag, If the teleprinter is being written 
to, the Write Request Delay (WRD) bit should be set prior to any 
character transmission to initialize the interface for 300 baud, 


e Before each RDS instruction to read an USASCII character, clear 
the Read Request (RREQ) flag. 


4.2.4.1 WRITE/READ KSR EXAMPLE, The following program writes 10 
characters (each character is right-justified in a memory word) to the 
printer and then reads 10 characters from the keyboard. The data word of 
0158 1¢ associated with the first WDS instruction disables the I/O data bus 
interrupts from the data terminal, sets the transmission rate to 300 baud, 
and sets the Data Terminal Ready and Request to Send control bits. Refer 
to the WDS and RDS data word formats in figures 4-3 and 4-6, respectively, 
for aid in following the example. 


aac AERIS rere ry SR NE A POS PS a RESERPINE FE 
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@LDA 
“WDS 
DATA 
LDX 
WRITE LDA 
AND 
@IOR 
WDS 
DATA 
BRU 
BIX 
LDX 
READ @LDA 
WDS 
DATA 
RDS 
DATA 
BRU 
AND 
TOR 
STA 
BIX 
QUT DATA 
IN BSS 


CONTROL DATA,300 BAUD, TERMNL RDY 
OUT TO INTERFACE 
NO BUSY BIT (NO CHARACTER) 


GET CHAR,RIGHT ADJUST 

MASK OUT MSB 

LOAD ASCII DATA,CLR WREQ 

WRITE CHARACTER & CONTROL DATA 
BUSY BIT 


LOOP BACK 


CLR READ REQUEST 
QUT TO INTERFACE 
NO BUSY BIT 

READ CHARACTER 
BUSY BIT 


SAVE 7-BIT LSB CHARACTER 
OR IN 8TH USASCII BIT (ONE), MARK PARITY 


PGE ACR ASG TE RS 


10 


4.2.4.2 ASR SUBCOMMAND EXAMPLE, The following program puts 
cassette 1 in the record mode (and cassette 2 in the playback mode), loads 
cassette 1, and initiates the recording process, Note that the DLE char- 
acter code (0010)¢) accompanies each of the two-character functions, The 
program assumes a WDS instruction has already been executed and cassette 
1 is positioned on the clear leader at the beginning of the tape. 
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LDA 
@IOR 
WDS 
DATA 
BRU 
LDA 
@IOR 
WDS 
DATA 
BRU 
LDA 
@IOR 
WDS 
DATA 
BRU 
LDA 
@IOR 
WDS 
DATA 
BRU 
LDA 
@IOR 
WDS 
DATA 
BRU 


DLE USASCII CODE 
LOAD USASCII DATA, CLR WREQ 
ASR 

BUSY BIT 

BRANCH IF NO DATA XFER 
CASSETTE 1 TO RECORD MODE CODE 
LOAD USASCII DATA, CLR WREQ 
ASR 

BUSY BIT | 

BRANCH IF NO XFER 

DLE USASCII CODE 

LOAD USASCII DATA, CLEAR WREQ 
ASR 

BUSY BIT 

BRANCH IF NO XFER 

LOAD CASSETTE 1 CODE 

LOAD USASCII DATA, CLEAR WREQ 
ASR 

BUSY BIT 

BRANCH IF NO XFER 

DC2, RECORD-ON CODE 

LOAD USASCII DATA, CLEAR WREQ 
ASR 

BUSY BIT 

BRANCH IF NO XFER 


Additional examples of the ADC (single-character) functions are provided in 
the ASR read and write programs in the following paragraphs, 


4.2.4.3 WRITE ASR EXAMPLE. 


The following program initiates the 


cassette recording process, writes 10 USASCII characters to the cassette, 


and terminates the cassette recording process. 
the busy bit test associated with the first WDS instruction. 


does not use interrupts. 


Note the alternate method of 
This program 
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LDA =>12 SEND DC2 (RECORD-ON) 
@IOR =>5000 LOAD USASCII DATA, CLR WREQ 
WDS 5 TO ASR , 
DATA 0 FROM REG A, NO BUSY BIT 
RDS = 5 
Replaces })DATA 0 
Busy Bit a “1 
BRU —s $3 
LDX =-10 
WRITE LDA OUT+10,X 
AND =>7F MASK BITS 0-TO-8 TO ZEROES 
@IOR  =>5000 LOAD USASCII DATA, CLR WREQ 
WDS 5 
DATA »>80 
BRU $-2 
BIX WRITE 
LDA =>]4 SEND DC4 (RECORD-OFF) 
@IOR =>5000 LOAD USASCII DATA, CLR WREQ 
WDS 5 
DATA >80 
BRU = $2 
ae oe WRITE OVER RECORD-OFF CHARACTER (DELETE) 
DATA >80 
BRU = $-2 
OUT DATA. *CHARAC TERS" 


4.2.4.4 READ ASR EXAMPLE. The following program reads 10 source 
records from a cassette, assuming each source record is less than or equal 
to 200 bytes. Note that the count of source records is maintained by keeping 
track of the number of DC3 characters (playback off) encountered. The DC3 
character is used in programs that run under a monitor (supervisor), where 
each source line is terminated by a carriage return, line feed, DC3, and 
RUB OUT (delete). Stand-alone programs can use whatever conventions are 
necessary to end source lines. This program does not use interrupts; a 
wait loop is entered prior to reading each character from the cassette. 
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Designate Amt of 
Records to Read 


Wait 
for 
Data 


End-of-Record 


Check 


Count of 


Records Read 


LDA 
STA 
LDX 
LDA 
@IOR 
WDS 
DATA 
RDS 
DATA 
BRU 
AND 
CPL 
SNE 
BRU 
1OR 
STA 
RIN 
@LDA 


START — 


READ 


BRU . 


FINISH { DMT 
eee 
IDL 
COUNT DATA 
TABLE BSS 


> 80 
$-2 
=> 7F 
=> 13 


FINISH 

= > 80 
TABLE,X 
X,X 

= > 8000 
READ 
COUNT 
START 


1000 


AMT RECORDS TO READ 

STORE AMT OF RECORDS 

CHARACTER STORAGE POINTER 

PLAYBACK ON (DC1), BEGIN READING RECORD 
CLEAR RRO & WREO, WRITE CHARS 

WRITE COMMAND & CHARACTER DATA 

NO BUSY BIT (DC1 IS 1ST WDS) 

READ DATA FROM ASR 

BUSY BIT, REGISTER A 


MASK OUT 9 MSB 

CHK IF DC3 (PLYBCK OFF) READ 

DC3 READ? SKIP NEXT IF NOT READ 
BRANCH IF DC3 READ 

7 BIT ASCII TO 8 BIT ASCII, MARK PARITY 
STORE CHARACTER 

INCREMENT X-REG 

SET CLR READ REO (CRR) 

RESTART CHARACTER CYCLE 
DECREMENT COUNT, SKIP NEXT IF COUNT = 0 
GO TO NEXT RECORD 

IDLE WHEN COUNT =0 

CONTAINS AMT OF RECORDS. 

STORAGE AREA 
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USASCIL CHARACTERS 
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e-V/I-V 
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000 
000 
000 
000 
000 
000 
000 
000 
000 
000 
000 
000 
000 
000 
000 
000 


001 
001 
001 
001 
001 
001 
001 
001 
001 
001 
001 
001 
001 
001 
001 
001 


0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 
1011 
1100 
1101 
1110 
11 


0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 
1011 
1100 
110] 
1110 
111 


APPENDIX A 


USASCII CHARACTERS BY NUMERICAL SEQUENCE 


Nul] 

Start Heading 
Start Text 

End Text 

End Transmission 
Enquiry 
Acknowledge 

Bel] 

Backspace 
Horizontal Tab 


' Line Feed 


Vertical Tab 
Form Feed 
Carriage Return 
Shift Out 

Shift In 


Data Link Escape 
Device Control 1 
Device Control 2 
Device Control 3 
Device Control 4 
Negative Acknowledge 
Synchronous Idle 

End Transmission Bloc 
Cancel 
End Medium 
Substitute 

Escape 

File Separator 

Group Separator 
Record Separator 
Unit Separator 


010 
010 
010 
010 
010 


-010 


010 
010 
010 
010 
010 
010 
010 
010 
010 
010 


011 
011 
011 
011] 
011 
011 
011 
011 
011] 
011 
011 
011 
011 
011 
011 
011 


0000 — 


0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 
1011 
1100 
1101 
1110 
1111 


0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 
1011 
1100 
1101 
1110 
1111 


Space 


Pe tb eNO - ROSL HHH TO 


WONNAOP WM — © “Ne 


/\ we oe 
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100 
100 
100 
100 
100 
100 
100 
100 
100 
100 
100 
100 
100 
100 
100 
100 


10] 
101 
101] 
101 
101 
10] 
101 
101 
101 
101 
101 
101 
101 
101 
101 
10] 


1. In memory, the most significant bit is undefined and 
2. The limited USASCIT character set includes only 2076 


0000 40 
0001 41 
0010 42 
0011 43 
0100 44 
0101 45 
0110 46 
O11 47 
1000 48 
1001 49 
1010 4A 
1011 4B 
1100 = 4C 
1101 4D 
1110 4E 
W110 4F 
0000 50 
0001 51 
0010 52 
0011 53 
0100 54 
0101 55 
0110 56 
O1l1l1 57 
1000 «58 
1001 59 
1010 5A 
1011 5B 
1100 —-5C 
1101 5D 
1110 5E 
111 5F 


either a zero or one is acceptable. 


through 5Fy7¢. 


WANK Ke EK CHNDWOVU Ot SET KOHTOMMOOWTre 


sort 
or 


110 
110 
110 
110 
110 
110 
110 


~ 7110 


110 
110 
110 
110 
110 
110 
110 
110 


111 
1 
W1 
1 
11 
111 
111 
11 
11 
11 
WW 
111 
1 
11 
11 
11 


0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 
1011 
1100 
1101 
1110 
111 


0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 
1011] 
1100 
71101 
1110 
111 


os3 3 -nwnom] TO h»DoDaQaanw”A 7 


ww me NG K BE cK OCtn st Aw 


Delete 


VELb6- 196196 


CUT ALONG LINE 


USER’S RESPONSE SHEET 


Model 980 Computer Assembly Language 
Manual Title: Input/Output (961 961-9734) 


Date of Manual: 1 October 1974 Date of This Letter: 
User: Office/Dept. No.: 
Company: 


Street Address: 


City/State/Zip: 


Please list any discrepancy foundin this manual by page, paragraph, figure, 
or table number in the following space. If there are any other suggestions 
that you wish to make, feel free to include them, Thank you. 


Location Comment/Suggestion | 
in Manual 


NO POSTAGE NECESSARY IF MAILED IN U.S.A. 
FOLD ON TWO LINES (LOCATED ON REVERSE SIDE), STAPLE AND MAIL 


First Class - 


PERMIT NO. 3135 
Austin, Texas 


BUSINESS REPLY MAIL 
No Postage Necessary if Mailed in the United States 


Postage Will Be Paid by 


TEXAS INSTRUMENTS INCORPORATED 
DIGITAL SYSTEMS DIVISION 


P.O. BOX 2909 - AUSTIN, TEXAS 78767 
Attn: TECHNICAL PUBLICATIONS, MS 2146 


——_———_ TP aS EP Se Sel loi 0 ee 0 cme ee ee eee 0 ee 0 ee 0 0 ere, 0 eee: 


Sales and Service Offices of Texas Instruments are located 
throughout the United States and in major countries 


overseas. Contact the Digital Systems Division, : 
Texas Instruments Incorporated, P.O. Box 1444, 
Houston, Texas 77001, or call (713) 494-5115, i 
for the location of the office nearest to you. 


Texas Instruments reserves the right to make changes at any time to 
improve design and supply the best product possible. 


TEXAS INSTRUMENTS 


INCORPORATED 


